From f50e8e60e9da99e4f69d8ab76810dc7e5fb448bc Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期一, 02 十二月 2024 10:29:09 +0800 Subject: [PATCH] 2024年12月02日10:29:05 --- app/src/main/java/com/hdl/photovoltaic/ui/message/MessageInfoActivity.java | 181 ++++++++++++++++++++++++++++++++++++++------- 1 files changed, 153 insertions(+), 28 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageInfoActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageInfoActivity.java index 044b216..9a693c4 100644 --- a/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageInfoActivity.java +++ b/app/src/main/java/com/hdl/photovoltaic/ui/message/MessageInfoActivity.java @@ -4,18 +4,28 @@ import android.graphics.drawable.Drawable; import android.os.Bundle; import android.view.View; +import android.widget.TextView; import androidx.appcompat.content.res.AppCompatResources; +import com.google.gson.Gson; 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.ActivityMessageInfoBinding; +import com.hdl.photovoltaic.enums.MessageAlarmStateType; +import com.hdl.photovoltaic.enums.MessageStateType; import com.hdl.photovoltaic.listener.CloudCallBeak; +import com.hdl.photovoltaic.other.HdlCommonLogic; import com.hdl.photovoltaic.other.HdlMessageLogic; import com.hdl.photovoltaic.other.HdlThreadLogic; import com.hdl.photovoltaic.ui.bean.MessageBean; import com.hdl.photovoltaic.utils.TimeUtils; +import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; + +import org.greenrobot.eventbus.EventBus; /** * 娑堟伅璇︽儏 @@ -26,7 +36,6 @@ private MessageBean mMessageBean; - private String mMsgId; @Override public Object getContentView() { @@ -39,7 +48,11 @@ setNotificationBarBackgroundColor(CustomColor.white); setStatusBarTextColor(); try { - mMsgId = getIntent().getStringExtra("msgId"); + String json = getIntent().getStringExtra("messageBean"); + mMessageBean = new Gson().fromJson(json, MessageBean.class); + if (mMessageBean == null) { + mMessageBean = new MessageBean(); + } } catch (Exception ignored) { } @@ -54,7 +67,7 @@ private void readData() { // showLoading(); - HdlMessageLogic.getInstance().getMessageInfo(mMsgId, new CloudCallBeak<MessageBean>() { + HdlMessageLogic.getInstance().getMessageInfo(mMessageBean.getMsgId().toString(), new CloudCallBeak<MessageBean>() { @Override public void onSuccess(MessageBean msg) { HdlThreadLogic.runMainThread(new Runnable() { @@ -71,23 +84,21 @@ viewBinding.messageInfoAlarmDeviceIn.rightContentTv.setText(mMessageBean.getDeviceDesc()); viewBinding.messageInfoAlarmRangeIn.rightContentTv.setText(mMessageBean.getEffectScopeDesc()); viewBinding.messageInfoPowerStationLocationIn.rightContentTv.setText(mMessageBean.getLocationAddress()); - String date = TimeUtils.getDateTimestamp(mMessageBean.getCreateTime()); + String date = TimeUtils.getTimeFromTimestamp(mMessageBean.getCreateTime()); viewBinding.messageInfoAlarmTimeIn.rightContentTv.setText(date); + stateStyle(viewBinding.messageInfoAlarmStateTv); - String type = "";//FAULT:鏁呴殰,WARN:鍛婅,EVENT:浜嬩欢 - Drawable drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); - if (mMessageBean.getType().equals("FAULT")) { - type = _mActivity.getString(R.string.my_power_station_malfunction); - drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_e34343); - } else if (mMessageBean.getType().equals("WARN")) { - type = _mActivity.getString(R.string.message_alarm); - drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); - } else if (mMessageBean.getType().equals("EVENT")) { - type = "浜嬩欢"; - drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); + if (mMessageBean.getStatus().equals(MessageStateType.processed)) { + //宸茬粡瑙e喅鎺夌殑闅愯棌 + viewBinding.messageInfoBackTv.setVisibility(View.GONE); + viewBinding.messageInfoSolveTv.setVisibility(View.GONE); + } else { + if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + return; + } + viewBinding.messageInfoBackTv.setVisibility(View.GONE); + viewBinding.messageInfoSolveTv.setVisibility(View.GONE); } - viewBinding.messageInfoAlarmStateTv.setText(type); - viewBinding.messageInfoAlarmStateTv.setBackground(drawable); } }); } @@ -101,26 +112,71 @@ } private void initEvent() { - viewBinding.toolbarTopIn.topBackBtn.setOnClickListener(new View.OnClickListener() { + //鍚庨��鐨勪簨浠� + viewBinding.toolbarTopIn.topBackLl.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { + if (mMessageBean == null) { + finish(); + return; + } + //鏈鐞� + if (mMessageBean.getStatus().equals(MessageStateType.untreated)) { + //鏀瑰彉缂撳瓨鐘舵�� + if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.untreated); + //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); + } else { + //闄も�滄晠闅溾�濆锛屽叾浠栫瓑绾т俊鎭�滃凡璇烩�濆悗锛岃嚜鍔ㄧЩ鍑衡�滃彂鐢熶腑鈥濆垪琛ㄥ苟鍔犲叆鈥滃巻鍙茶褰曗�濆垪琛� + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.processed); + sendEventBus(); + } + + } finish(); } }); - + //杩斿洖鐨勪簨浠� viewBinding.messageInfoBackTv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { + if (mMessageBean == null) { + finish(); + return; + } + //鏈鐞� + if (mMessageBean.getStatus().equals(MessageStateType.untreated)) { + //鏀瑰彉缂撳瓨鐘舵�� + if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.untreated); + //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); + } else { + //闄も�滄晠闅溾�濆锛屽叾浠栫瓑绾т俊鎭�滃凡璇烩�濆悗锛岃嚜鍔ㄧЩ鍑衡�滃彂鐢熶腑鈥濆垪琛ㄥ苟鍔犲叆鈥滃巻鍙茶褰曗�濆垪琛� + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.processed); + sendEventBus(); + } + } finish(); } }); + //宸插鐞嗙殑浜嬩欢 viewBinding.messageInfoSolveTv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - HdlMessageLogic.getInstance().getMessageMessageSolve(mMsgId, new CloudCallBeak<Boolean>() { + HdlMessageLogic.getInstance().getMessageMessageSolve(mMessageBean.getMsgId().toString(), new CloudCallBeak<Boolean>() { @Override public void onSuccess(Boolean obj) { + if (mMessageBean == null) { + return; + } + //鏈鐞� + if (mMessageBean.getStatus().equals(MessageStateType.untreated)) { + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.processed); + sendEventBus(); + } finish(); } @@ -136,12 +192,27 @@ } + /** + * 閫氱煡鍑哄幓澶栭潰鏇存柊鏁版嵁 + */ + private void sendEventBus() { + //閫氱煡宸插鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.processed); + //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); + } + + private void initView() { viewBinding.toolbarTopIn.topTitleTv.setText(R.string.message_alarm_info); - viewBinding.toolbarTopIn.topTitleTv.setTextColor(getResources().getColor(R.color.text_030D1C, null)); - viewBinding.toolbarTopIn.topBackBtn.setVisibility(View.VISIBLE); - viewBinding.toolbarTopIn.topBarView.setBackgroundColor(getResources().getColor(R.color.text_FFFFFFFF, null)); + viewBinding.toolbarTopIn.topBackLl.setVisibility(View.VISIBLE); + + if (!UserConfigManage.getInstance().isBAccount()) { + viewBinding.messageInfoBackTv.setTextColor(getColor(R.color.text_38C494)); + viewBinding.messageInfoBackTv.setBackground(AppCompatResources.getDrawable(_mActivity, R.drawable.fillet_line_38c494)); + viewBinding.messageInfoSolveTv.setBackground(AppCompatResources.getDrawable(_mActivity, R.drawable.checked_38c494)); + } viewBinding.messageInfoAlarmContentIn.leftTitleTv.setText(R.string.messagealarm_details_content); viewBinding.messageInfoAlarmDeviceIn.leftTitleTv.setText(R.string.messagealarm_details_device); @@ -149,10 +220,64 @@ viewBinding.messageInfoPowerStationLocationIn.leftTitleTv.setText(R.string.message_alarm_detailspower_station_location); viewBinding.messageInfoAlarmTimeIn.leftTitleTv.setText(R.string.message_alarm_details_time); - viewBinding.messageInfoAlarmContentIn.rightContentTv.setText(""); - viewBinding.messageInfoAlarmDeviceIn.rightContentTv.setText(""); - viewBinding.messageInfoAlarmRangeIn.rightContentTv.setText(""); - viewBinding.messageInfoPowerStationLocationIn.rightContentTv.setText(""); - viewBinding.messageInfoAlarmTimeIn.rightContentTv.setText(""); + viewBinding.messageInfoHomeNameTv.setText(mMessageBean.getHomeName()); + viewBinding.messageInfoAlarmContentIn.rightContentTv.setText(mMessageBean.getTitle()); + viewBinding.messageInfoAlarmDeviceIn.rightContentTv.setText(mMessageBean.getDeviceDesc()); + viewBinding.messageInfoAlarmRangeIn.rightContentTv.setText(mMessageBean.getEffectScopeDesc()); + viewBinding.messageInfoPowerStationLocationIn.rightContentTv.setText(mMessageBean.getLocationAddress()); + String date = TimeUtils.getTimeFromTimestamp(mMessageBean.getCreateTime()); + viewBinding.messageInfoAlarmTimeIn.rightContentTv.setText(date); + stateStyle(viewBinding.messageInfoAlarmStateTv); + + + if (mMessageBean.getStatus().equals(MessageStateType.untreated) && mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + //鍙戠敓涓殑娑堟伅涓旀槸鏁呴殰鎵嶈鏄剧ず + viewBinding.messageInfoWorkOut.setVisibility(View.VISIBLE); + } + } + + + /** + * 鐘舵�佹牱寮� + * + * @param textView 缁勪欢 + */ + private void stateStyle(TextView textView) { + String type = "";//FAULT:鏁呴殰,WARN:鍛婅,EVENT:浜嬩欢 + Drawable drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.device_satte_ffb300); + if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + type = _mActivity.getString(R.string.my_power_station_malfunction); + drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.device_state_fff55252); + } else if (mMessageBean.getType().equals(MessageAlarmStateType.warn)) { + type = _mActivity.getString(R.string.message_alarm); + drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.device_satte_ffb300); + } else if (mMessageBean.getType().equals(MessageAlarmStateType.event)) { + type = _mActivity.getString(R.string.loading_title_tip); + drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.device_state_ffb9b9b9); + } + textView.setText(type); + textView.setBackground(drawable); + } + + @Override + public void onBackPressed() { + super.onBackPressed(); + if (mMessageBean == null) { + return; + } + //鏈鐞� + if (mMessageBean.getStatus().equals(MessageStateType.untreated)) { + //鏀瑰彉缂撳瓨鐘舵�� + if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.untreated); + //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); + } else { + //闄も�滄晠闅溾�濆锛屽叾浠栫瓑绾т俊鎭�滃凡璇烩�濆悗锛岃嚜鍔ㄧЩ鍑衡�滃彂鐢熶腑鈥濆垪琛ㄥ苟鍔犲叆鈥滃巻鍙茶褰曗�濆垪琛� + HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.processed); + sendEventBus(); + } + + } } } \ No newline at end of file -- Gitblit v1.8.0