From 3f617fbe58fd89a61e2f4013fe80dba673fbd7ae Mon Sep 17 00:00:00 2001 From: mac <user@users-MacBook-Pro.local> Date: 星期四, 19 九月 2024 14:38:24 +0800 Subject: [PATCH] 2024年09月19日14:38:04 --- app/src/main/java/com/hdl/photovoltaic/ui/message/MessageInfoActivity.java | 137 ++++++++++++++++++++++++++++++--------------- 1 files changed, 91 insertions(+), 46 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 c0b0223..63ab6ef 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 @@ -1,13 +1,14 @@ package com.hdl.photovoltaic.ui.message; -import android.annotation.SuppressLint; 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; @@ -17,6 +18,7 @@ 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; @@ -34,7 +36,6 @@ private MessageBean mMessageBean; - private String mMsgId; @Override public Object getContentView() { @@ -47,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) { } @@ -62,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() { @@ -81,24 +86,16 @@ viewBinding.messageInfoPowerStationLocationIn.rightContentTv.setText(mMessageBean.getLocationAddress()); String date = TimeUtils.getTimeFromTimestamp(mMessageBean.getCreateTime()); viewBinding.messageInfoAlarmTimeIn.rightContentTv.setText(date); - - String type = "";//FAULT:鏁呴殰,WARN:鍛婅,EVENT:浜嬩欢 - Drawable drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); - if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { - type = _mActivity.getString(R.string.my_power_station_malfunction); - drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_e34343); - } else if (mMessageBean.getType().equals(MessageAlarmStateType.warn)) { - type = _mActivity.getString(R.string.message_alarm); - drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); - } else if (mMessageBean.getType().equals(MessageAlarmStateType.event)) { - type = _mActivity.getString(R.string.event); - drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); - } - viewBinding.messageInfoAlarmStateTv.setText(type); - viewBinding.messageInfoAlarmStateTv.setBackground(drawable); + stateStyle(viewBinding.messageInfoAlarmStateTv); 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); } @@ -116,7 +113,7 @@ 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) { @@ -125,14 +122,11 @@ } //鏈鐞� if (mMessageBean.getStatus().equals(MessageStateType.untreated)) { - //鏀瑰彉缂撳瓨鐘舵�� if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.untreated); - BaseEventBus baseEventBus = new BaseEventBus(); - baseEventBus.setTopic(ConstantManage.message_function_push_post); - baseEventBus.setType(MessageStateType.untreated); - EventBus.getDefault().post(baseEventBus); + //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); } else { //闄も�滄晠闅溾�濆锛屽叾浠栫瓑绾т俊鎭�滃凡璇烩�濆悗锛岃嚜鍔ㄧЩ鍑衡�滃彂鐢熶腑鈥濆垪琛ㄥ苟鍔犲叆鈥滃巻鍙茶褰曗�濆垪琛� HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.processed); @@ -156,10 +150,8 @@ //鏀瑰彉缂撳瓨鐘舵�� if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.untreated); - BaseEventBus baseEventBus = new BaseEventBus(); - baseEventBus.setTopic(ConstantManage.message_function_push_post); - baseEventBus.setType(MessageStateType.untreated); - EventBus.getDefault().post(baseEventBus); + //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); } else { //闄も�滄晠闅溾�濆锛屽叾浠栫瓑绾т俊鎭�滃凡璇烩�濆悗锛岃嚜鍔ㄧЩ鍑衡�滃彂鐢熶腑鈥濆垪琛ㄥ苟鍔犲叆鈥滃巻鍙茶褰曗�濆垪琛� HdlMessageLogic.getInstance().setMessageState(mMessageBean.getMsgId(), true, MessageStateType.processed); @@ -174,7 +166,7 @@ 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) { @@ -186,8 +178,6 @@ sendEventBus(); } finish(); - - } @Override @@ -207,15 +197,9 @@ */ private void sendEventBus() { //閫氱煡宸插鐞嗚鏇存柊鏁版嵁 - BaseEventBus processedBus = new BaseEventBus(); - processedBus.setTopic(ConstantManage.message_function_push_post); - processedBus.setType(MessageStateType.processed); - EventBus.getDefault().post(processedBus); + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.processed); //閫氱煡鏈鐞嗚鏇存柊鏁版嵁 - BaseEventBus untreatedBus = new BaseEventBus(); - untreatedBus.setTopic(ConstantManage.message_function_push_post); - untreatedBus.setType(MessageStateType.untreated); - EventBus.getDefault().post(untreatedBus); + HdlCommonLogic.getInstance().postEventBus(ConstantManage.message_function_push_post, MessageStateType.untreated); } @@ -223,7 +207,7 @@ 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.topBackLl.setVisibility(View.VISIBLE); viewBinding.toolbarTopIn.topBarView.setBackgroundColor(getResources().getColor(R.color.text_FFFFFFFF, null)); if (!UserConfigManage.getInstance().isBAccount()) { @@ -238,10 +222,71 @@ 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.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); + } + } + + + /** + * 鐘舵�佹牱寮� + * + * @param textView 缁勪欢 + */ + private void stateStyle(TextView textView) { + String type = "";//FAULT:鏁呴殰,WARN:鍛婅,EVENT:浜嬩欢 + Drawable drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); + if (mMessageBean.getType().equals(MessageAlarmStateType.fault)) { + type = _mActivity.getString(R.string.my_power_station_malfunction); + drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_e34343); + } else if (mMessageBean.getType().equals(MessageAlarmStateType.warn)) { + type = _mActivity.getString(R.string.message_alarm); + drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.alarm_ffb300); + } else if (mMessageBean.getType().equals(MessageAlarmStateType.event)) { + type = _mActivity.getString(R.string.loading_title_tip); + drawable = AppCompatResources.getDrawable(_mActivity, R.drawable.state_b9b9b9); + } + 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