From 637e3152e3bfea430ca774c7dd178b4b9696c37f Mon Sep 17 00:00:00 2001 From: mac <user@users-MacBook-Pro.local> Date: 星期二, 26 十二月 2023 17:11:58 +0800 Subject: [PATCH] 2023年12月26日17:11:48 --- app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java | 85 +++++++++++++++++++++++++++++++++++++++--- 1 files changed, 78 insertions(+), 7 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java b/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java index a4ce9c2..4fbc266 100644 --- a/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java +++ b/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java @@ -1,14 +1,21 @@ package com.hdl.photovoltaic.ui.message; +import android.content.Intent; import android.os.Bundle; import androidx.recyclerview.widget.LinearLayoutManager; +import androidx.swiperefreshlayout.widget.SwipeRefreshLayout; +import com.hdl.linkpm.sdk.core.exception.HDLException; +import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.base.CustomBaseFragment; import com.hdl.photovoltaic.config.ConstantManage; import com.hdl.photovoltaic.databinding.FragmentRecoverMessageBinding; +import com.hdl.photovoltaic.enums.MessageFunctionTabSwitch; +import com.hdl.photovoltaic.listener.CloudCallBeak; import com.hdl.photovoltaic.other.HdlCommonLogic; import com.hdl.photovoltaic.other.HdlLogLogic; +import com.hdl.photovoltaic.other.HdlMessageLogic; import com.hdl.photovoltaic.ui.adapter.MessageAdapter; import com.hdl.photovoltaic.ui.bean.MessageBean; import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; @@ -25,7 +32,8 @@ private MessageAdapter messageRecoverAdapter; - private List<MessageBean> mList; + private final List<MessageBean> mList = new ArrayList<>(); + @Override public Object getContentView() { viewBinding = FragmentRecoverMessageBinding.inflate(getLayoutInflater()); @@ -34,6 +42,7 @@ @Override public void onBindView(Bundle savedInstanceState) { + //鍒濆鍖栨暟鎹� initData(); //鍒濆鍖栫晫闈� @@ -43,22 +52,36 @@ } private void initData() { - mList = new ArrayList<>(); - for (int i = 0; i < 5; i++) { + for (int i = 0; i < 2; i++) { MessageBean messageBean = new MessageBean(); - messageBean.setContent("鏉ヤ簡涓�鏉″憡璀︿俊鎭�" + i); +// messageBean.setContent("鏉ヤ簡涓�鏉″憡璀︿俊鎭�" + i); messageBean.setHomeName(i + ""); - messageBean.setTime("2023-12-06-15"); +// messageBean.setTime("2023-12-06-15"); messageBean.setRead(false); mList.add(messageBean); } } private void initEvent() { + //璁剧疆涓嬫媺绠ご棰滆壊 + viewBinding.messageRecoverSrl.setColorSchemeResources(R.color.text_FF245EC3); + viewBinding.messageRecoverSrl.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { + @Override + public void onRefresh() { + mList.clear();//琛ㄧず寮哄埗閲嶆柊璇锋眰娑堟伅鍒楄〃 + getRecoverMessageList(false); + HdlLogLogic.print("RecoverMessageFragment涓嬫媺鍒锋柊", false); + } + }); messageRecoverAdapter.setNoOnclickListener(new MessageAdapter.OnclickListener() { @Override public void onClick(int position, MessageBean item) { - + Intent intent = new Intent(); + Bundle bundle = new Bundle(); + bundle.putSerializable("message_info", MessageBean.class); + intent.putExtras(bundle); + intent.setClass(_mActivity, MessageInfoActivity.class); + startActivity(intent); } }); } @@ -69,19 +92,67 @@ viewBinding.messageRecoverRecyclerview.setAdapter(messageRecoverAdapter); } + + /** + * 鍒锋柊鍒楄〃鏁版嵁 + */ private void updateListData() { if (this.messageRecoverAdapter != null) { + this.messageRecoverAdapter.setList(mList); this.messageRecoverAdapter.notifyDataSetChanged(); } } + @Override public void onEventMessage(BaseEventBus eventBus) { super.onEventMessage(eventBus); //鎺ユ敹澶栭儴鐐瑰嚮浜嬩欢 if (eventBus.getTopic().equals(ConstantManage.message_function_tab_switch)) { - if (eventBus.getType().equals(HdlCommonLogic.MessageFunctionTabSwitch.recover.toString())) { + if (eventBus.getType().equals(MessageFunctionTabSwitch.recover.toString())) { HdlLogLogic.print("姝e湪鐐瑰嚮銆愬凡鎭㈠銆�"); + getRecoverMessageList(true); } } } + + + /** + * 鑾峰彇鎭㈠涓殑娑堟伅鍒楄〃 + * + * @param isShowLoading 鏄惁鍚姩 true鍚姩 + */ + private void getRecoverMessageList(boolean isShowLoading) { + + if (mList.size() == 0) { + if (isShowLoading) { + showLoading(); + } + HdlMessageLogic.getInstance().getMessageList(HdlMessageLogic.MessageStatus.processed, new CloudCallBeak<List<MessageBean>>() { + @Override + public void onSuccess(List<MessageBean> list) { + if (isShowLoading) { + hideLoading(); + } + if (!isShowLoading) { + viewBinding.messageRecoverSrl.setRefreshing(false); + } + + if (list != null && list.size() != 0) { + mList.addAll(list); + updateListData(); + } + } + + @Override + public void onFailure(HDLException e) { + if (isShowLoading) { + hideLoading(); + } + if (!isShowLoading) { + viewBinding.messageRecoverSrl.setRefreshing(false); + } + } + }); + } + } } -- Gitblit v1.8.0