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 | 197 ++++++++++++++++++++++++++++-------------------- 1 files changed, 115 insertions(+), 82 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 3207246..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 @@ -3,7 +3,11 @@ 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; @@ -11,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; @@ -29,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; /** @@ -46,7 +55,6 @@ private HouseListAdapter houseListAdapter; private List<HouseIdBean> houseListBeanIDList; - private boolean is_edit = false;//琛ㄧず鏄惁鍦ㄧ紪杈戠姸鎬�(true=鍦ㄧ紪杈戠姸鎬�) @Override public Object getContentView() { @@ -57,20 +65,22 @@ @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() { @@ -78,33 +88,16 @@ 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.toolbarTopRl.topMoreBtn.setVisibility(View.VISIBLE); - initData();//鍒濆鍖栫紦瀛樻暟鎹� - setAllItemEdit(false); - houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃 + finish(); } }); //缂栬緫鎸夐挳 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.toolbarTopRl.topMoreBtn.setVisibility(View.GONE); - initData();//鍒濆鍖栫紦瀛樻暟鎹� - setAllItemEdit(true); - houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃 + Intent intent = new Intent(); + intent.setClass(_mActivity, PowerStationsMoveActivity.class); + startActivity(intent); } }); @@ -118,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) { @@ -165,29 +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); } }); @@ -195,9 +155,7 @@ } private void initView() { - viewBinding.toolbarTopRl.getRoot().setBackgroundColor(getColor(R.color.text_FFECECEC)); viewBinding.toolbarTopRl.topBackLl.setVisibility(View.VISIBLE); - viewBinding.toolbarTopRl.topLeftIv.setImageResource(R.drawable.back_c); viewBinding.toolbarTopRl.topTitleTv.setText(R.string.power_station_selection); viewBinding.toolbarTopRl.topMoreBtn.setVisibility(View.VISIBLE); viewBinding.toolbarTopRl.topMoreIv.setImageResource(R.drawable.editor_house); @@ -226,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); } @@ -253,6 +217,8 @@ viewBinding.fragmentHouseSrl.setRefreshing(false); } + HdlThreadLogic.toast(_mActivity, e.getMsg() + "(" + e.getCode() + ")"); + } }, _mActivity, ShowErrorMode.YES); } @@ -260,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); } } } @@ -296,7 +258,7 @@ 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()); @@ -374,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