From d1ebb94e1a17b7c25d4fcf73d85345d92cc86b5c Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 02 一月 2024 18:41:34 +0800
Subject: [PATCH] 2024年01月02日18:41:32

---
 app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java |  256 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 217 insertions(+), 39 deletions(-)

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 fdff614..e5f3378 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
@@ -5,8 +5,6 @@
 import android.content.pm.PackageManager;
 import android.hardware.camera2.CameraManager;
 import android.os.Bundle;
-import android.os.SystemClock;
-import android.util.Log;
 import android.view.View;
 
 import androidx.annotation.NonNull;
@@ -14,37 +12,48 @@
 import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
 
 import com.google.gson.Gson;
-import com.google.gson.JsonObject;
+import com.hdl.linkpm.sdk.core.exception.HDLException;
 import com.hdl.photovoltaic.R;
+import com.hdl.photovoltaic.config.AppConfigManage;
+import com.hdl.photovoltaic.config.ConstantManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
 import com.hdl.photovoltaic.databinding.FragmentHouseListBinding;
 import com.hdl.photovoltaic.base.CustomBaseFragment;
-import com.hdl.photovoltaic.databinding.LoadingConfirmInputBinding;
+import com.hdl.photovoltaic.enums.HomepageTitleTabSwitch;
+import com.hdl.photovoltaic.enums.ShowErrorMode;
+import com.hdl.photovoltaic.listener.CloudCallBeak;
 import com.hdl.photovoltaic.other.HdlLogLogic;
+import com.hdl.photovoltaic.other.HdlResidenceLogic;
 import com.hdl.photovoltaic.other.HdlThreadLogic;
 import com.hdl.photovoltaic.other.HdlUniLogic;
 import com.hdl.photovoltaic.ui.adapter.HouseInfoAdapter;
-import com.hdl.photovoltaic.ui.bean.HouseListBean;
-import com.hdl.photovoltaic.ui.device.FastScanActivity;
+import com.hdl.photovoltaic.ui.bean.HouseIdBean;
 import com.hdl.photovoltaic.uni.HDLUniMP;
-import com.hdl.photovoltaic.uni.HDLUniMPSDKManager;
 import com.hdl.photovoltaic.utils.PermissionUtils;
-import com.hdl.photovoltaic.widget.ConfirmationInputDialog;
-
-import org.json.JSONException;
-import org.json.JSONObject;
+import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
+import com.hdl.sdk.link.core.utils.mqtt.MqttRecvClient;
 
 import java.util.ArrayList;
 import java.util.List;
 
-import io.dcloud.feature.unimp.DCUniMPJSCallback;
-
+/**
+ * (浣忓畢)鐢电珯鍒楄〃-鐣岄潰
+ */
 public class HouseListFragment extends CustomBaseFragment {
+
+    public static final String SORT_TYPE_1 = "powerSort";//鍙戠數鍔熺巼鎺掑簭
+    public static final String SORT_TYPE_2 = "todayElectricitySort";//浠婃棩鍙戠數閲忔帓搴�
+    public static final String SORT_TYPE_3 = "createTimeSort";//鍒涘缓鏃堕棿鎺掑簭
+    public static final String DESCENDING = "descending";//闄嶅簭
+    public static final String ASCENDING = "ascending";//鍗囧簭
+    public static final String SELECTED_SORT_TYPE = SORT_TYPE_1;
+    public static final String SELECTED_SORT = DESCENDING;
+
     private FragmentHouseListBinding viewBinding;
     private HouseInfoAdapter houseInfoAdapter;
     private CameraManager manager;
 
-    private List<HouseListBean> houseListBeanList = null;
+    private List<HouseIdBean> houseListBeanIDList = null;
 
 
     @Override
@@ -56,23 +65,48 @@
     @Override
     public void onBindView(Bundle savedInstanceState) {
         manager = (CameraManager) _mActivity.getSystemService(Context.CAMERA_SERVICE);
-
         initData();
         //鍒濆鍖�
         initView();
         //鍒濆鍖栫晫闈㈢洃鍚櫒
         initEvent();
-
+//        requestPermissions(new PermissionsResultCallback() {
+//            @Override
+//            public void succeed() {
+//
+//
+//            }
+//
+//            @Override
+//            public void failing() {
+//            }
+//        });
 
     }
 
     private void initEvent() {
 
+
+        //娣诲姞鐢电珯
         viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-                // 鎵撳紑灏忕▼搴忛〉闈�
-                HdlUniLogic.getInstance().openUniMP(HDLUniMP.UNI_EVENT_HOME_CREATION, null);
+                requestPermissions(new PermissionsResultCallback() {
+                    @Override
+                    public void succeed() {
+
+//                        Intent intent = new Intent();
+//                        intent.setClass(_mActivity, FastScanActivity.class);
+//                        startActivity(intent);
+//                        // 鎵撳紑灏忕▼搴忛〉闈�
+                        HdlUniLogic.getInstance().openUniMP(HDLUniMP.UNI_EVENT_OPEN_HOME_CREATION, null);
+                    }
+
+                    @Override
+                    public void failing() {
+                    }
+                });
+
             }
         });
         //璁剧疆涓嬫媺绠ご棰滆壊
@@ -80,58 +114,178 @@
         viewBinding.fragmentHouseSrl.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
             @Override
             public void onRefresh() {
-
-                viewBinding.fragmentHouseSrl.setRefreshing(false);
-                Log.d("HouseListFragment", "涓嬫媺鍒锋柊");
+                updateUIData(true);
+                HdlLogLogic.print("HouseListFragment涓嬫媺鍒锋柊", false);
             }
         });
         houseInfoAdapter.setNoOnclickListener(new HouseInfoAdapter.OnclickListener() {
             @Override
-            public void onClick(int position) {
+            public void onClick(int position, HouseIdBean houseIdBean) {
                 //鐐瑰嚮浣忓畢璇︽儏
-                HdlLogLogic.print("====鐐瑰嚮浣忓畢璇︽儏" + position);
-                if (houseListBeanList == null || houseListBeanList.size() <= 0) {
-                    return;
-                }
-                HouseListBean houseListBean = houseListBeanList.get(position);
-                String path = HDLUniMP.UNI_EVENT_HOME_CREATION + "?homeId=" + houseListBean.getHomeId();
+                HdlLogLogic.print("鐐瑰嚮浣忓畢璇︽儏--->" + new Gson().toJson(houseIdBean), false);
+                HdlResidenceLogic.getInstance().switchHouse(houseIdBean);
+                String path = HDLUniMP.UNI_EVENT_OPEN_HOME_DETAILS
+                        + "?homeId=" + houseIdBean.getHomeId()
+                        + "&homeName=" + houseIdBean.getHomeName()
+                        + "&powerStationStatus=" + houseIdBean.getPowerStationStatus();
                 HdlUniLogic.getInstance().openUniMP(path, null);
+
             }
         });
     }
 
     private void initView() {
-        viewBinding.toolbarTopFragmentHouseListRl.topTitleTv.setText(R.string.my_power_station_鎴戠殑鐢电珯);
+        viewBinding.toolbarTopFragmentHouseListRl.topTitleTv.setText(R.string.my_power_station);
         viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setVisibility(View.VISIBLE);
         viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setImageResource(R.drawable.add);
         LinearLayoutManager linearLayout = new LinearLayoutManager(_mActivity);
-        houseInfoAdapter = new HouseInfoAdapter(this.houseListBeanList);
+        houseInfoAdapter = new HouseInfoAdapter(_mActivity);
         viewBinding.fragmentHouseSrlListRc.setLayoutManager(linearLayout);
         viewBinding.fragmentHouseSrlListRc.setAdapter(houseInfoAdapter);
+        houseInfoAdapter.setList(this.houseListBeanIDList);
+        this.nullDataUpdateUi(houseListBeanIDList);
 
 
     }
 
     private void initData() {
-        this.houseListBeanList = new ArrayList<>();
-        for (int i = 0; i < 11; i++) {
-            HouseListBean houseListBean = new HouseListBean();
-            houseListBean.setHomeName("鐢电珯" + i);
-            this.houseListBeanList.add(houseListBean);
+        this.houseListBeanIDList = new ArrayList<>();
+        this.houseListBeanIDList.addAll(HdlResidenceLogic.getInstance().getHouseIdList());
+    }
+
+    /**
+     * 鏀跺埌EventBUs閫氱煡
+     *
+     * @param eventBus 鏁版嵁
+     */
+    @Override
+    public void onEventMessage(BaseEventBus eventBus) {
+        super.onEventMessage(eventBus);
+        if (HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL.equals(eventBus.getTopic())) {
+            if (HDLUniMP.UNI_EVENT_REPLY_HOME_CREATION.equals(eventBus.getType())) {
+                //uin鍒涘缓鐢电珯鎴愬姛鍚庨�氱煡
+                updateUIData(false);
+                if (eventBus.getData() != null) {
+                    Gson gson = new Gson();
+                    String json = eventBus.getData().toString();
+                    HouseIdBean houseIdBean = gson.fromJson(json, HouseIdBean.class);
+                    HdlResidenceLogic.getInstance().switchHouse(houseIdBean);
+
+                }
+            } else if (HDLUniMP.UNI_EVENT_REPLY_HOME_EDIT.equals(eventBus.getType())) {
+                //todo 鐜板湪榛樿鍒锋柊鍏ㄩ儴
+                //uin缂栬緫浣忓畢閫氱煡
+//                String homeId = HdlUniLogic.getInstance().getKeyValue("homeId", eventBus.getData());
+//                String home_name = HdlUniLogic.getInstance().getKeyValue("powerStationName", eventBus.getData());
+//                if (TextUtils.isEmpty(homeId) || TextUtils.isEmpty(home_name)) {
+//                    return;
+//                }
+//                int index = -1;
+//                for (int i = 0; i < houseListBeanIDList.size(); i++) {
+//                    HouseIdBean houseIdBean = houseListBeanIDList.get(i);
+//                    if (houseIdBean.getHomeId().equals(homeId)) {
+//                        index = i;
+//                        houseIdBean.setHomeName(home_name);
+//                        break;
+//                    }
+//                }
+//                if (index > -1) {
+//                    if (houseInfoAdapter != null) {
+//                        //鏇存柊鍗曚釜鏁版嵁
+//                        houseInfoAdapter.notifyItemChanged(index);
+//                    }
+//                }
+
+
+            }
+        } else if (HDLUniMP.UNI_EVENT_REPLY_HOME_CLOSE_HOME_DETAILS_PAGE.equals(eventBus.getType())) {
+            //uin鍏抽棴浣忓畢璇︽儏鐣岄潰閫氱煡
+            if (MqttRecvClient.getInstance() != null) {
+                MqttRecvClient.getInstance().removeAllTopic();
+            }
+            updateUIData(false);
+
+        } else if (HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST.equals(eventBus.getType())) {
+            //杩涘幓浣忓畢璇︽儏uni璇诲彇閫嗗彉鍣ㄥ垪琛ㄦ垚鍔熷悗閫氱煡
+//            for (int i = 0; i < HdlDeviceLogic.getInstance().getCurrentHomeGatewayList().size(); i++) {
+            //String gatewayId = HdlDeviceLogic.getInstance().getCurrentHomeGatewayList().get(i).getGatewayId();
+            //瀛楃涓叉槸鑷繁鎸夎鍒欐嫾鎺ョ殑,閲岄潰娉ㄥ唽涓婚鏃朵細瑙f瀽瀛楃涓�,鍙嬁getGatewayId()鍊�;
+            //String topic = "/user/" + gatewayId+"/1";
+            //杩涘幓浣忓畢璇︽儏寮�濮嬭闃呬富棰�
+            MqttRecvClient.getInstance().checkAndsubscribeAllTopics("");
+//            }
+        } else if (eventBus.getTopic().equals(ConstantManage.homepage_title_tab_switch)) {
+            //鎺ユ敹澶栭儴鐐瑰嚮浜嬩欢
+            if (eventBus.getType().equals(HomepageTitleTabSwitch.powerstation.toString())) {
+                HdlLogLogic.print("姝e湪鐐瑰嚮銆愮數绔欍��");
+            }
         }
+    }
 
+    /**
+     * 鍒锋柊UI
+     *
+     * @param isRefreshing 琛ㄧず鏄笅鎷夊埛鏂扮殑
+     */
+    private void updateUIData(boolean isRefreshing) {
+        //鑾峰彇浣忓畢(鐢电珯)ID鍒楄〃
+        HdlResidenceLogic.getInstance().getResidenceIdList("", "", new CloudCallBeak<List<HouseIdBean>>() {
+            @Override
+            public void onSuccess(List<HouseIdBean> list) {
+                HdlThreadLogic.runMainThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        if (isRefreshing) {
+                            //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦�
+                            viewBinding.fragmentHouseSrl.setRefreshing(false);
+                        }
+                        if (list != null && list.size() > 0) {
+                            //鏇存柊缂撳瓨
+                            HdlResidenceLogic.getInstance().setHouseIdList(list);
+                            if (houseInfoAdapter != null) {
+                                //鏇存柊UI
+                                houseInfoAdapter.setList(list);
+                            }
 
+                        }
+                        nullDataUpdateUi(list);
+                    }
+                }, _mActivity, ShowErrorMode.YES);
+
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                HdlThreadLogic.runMainThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        if (isRefreshing) {
+                            //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦�
+                            viewBinding.fragmentHouseSrl.setRefreshing(false);
+                        }
+
+                    }
+                }, _mActivity, ShowErrorMode.YES);
+            }
+        });
     }
 
     /**
      * 鐢宠鏉冮檺
      */
-    private void requestPermissions() {
-        String[] ary = PermissionUtils.checkPermission(_mActivity, new String[]{Manifest.permission.CAMERA});
+    private void requestPermissions(PermissionsResultCallback permissionsResultCallback) {
+
+
+        mPermissionsResultCallback = permissionsResultCallback;
+
+        String[] s = new String[]{Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.CAMERA,};
+        String[] ary = PermissionUtils.checkPermission(_mActivity, s);
         if (ary.length > 0) {
             requestPermissions(ary, PermissionUtils.STATUS_SUCCESS);
         } else {
-            startActivity(FastScanActivity.class);
+            if (mPermissionsResultCallback != null) {
+                mPermissionsResultCallback.succeed();
+            }
         }
     }
 
@@ -141,7 +295,9 @@
         if (requestCode == PermissionUtils.STATUS_SUCCESS) {
             for (int i = 0; i < permissions.length; i++) {
                 if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {
-                    startActivity(FastScanActivity.class);
+                    if (mPermissionsResultCallback != null) {
+                        mPermissionsResultCallback.succeed();
+                    }
                 }
 
             }
@@ -150,4 +306,26 @@
     }
 
 
+    private PermissionsResultCallback mPermissionsResultCallback;
+
+    public interface PermissionsResultCallback {
+
+        void succeed();
+
+        void failing();
+
+    }
+
+    /**
+     * 娌℃湁鐢电珯鍒楄〃鐨勬牱寮�
+     */
+    private void nullDataUpdateUi(List<HouseIdBean> list) {
+        if (list != null && list.size() > 0) {
+            viewBinding.nullListTv.setVisibility(View.GONE);
+        } else {
+            viewBinding.nullListTv.setVisibility(View.VISIBLE);
+        }
+    }
+
+
 }

--
Gitblit v1.8.0