diff --git a/app/src/main/java/com/yizhuan/erban/ui/im/bean/PrivateChatLimitInfo.java b/app/src/main/java/com/yizhuan/erban/ui/im/bean/PrivateChatLimitInfo.java index b646d0a72..ba65bc2e0 100644 --- a/app/src/main/java/com/yizhuan/erban/ui/im/bean/PrivateChatLimitInfo.java +++ b/app/src/main/java/com/yizhuan/erban/ui/im/bean/PrivateChatLimitInfo.java @@ -8,4 +8,6 @@ import lombok.Data; public class PrivateChatLimitInfo implements Serializable { private boolean chat; private String message; + private int wealthLevel; + private int charmLevel; } diff --git a/app/src/main/java/com/yizhuan/erban/ui/im/fragment/MessageFragment.java b/app/src/main/java/com/yizhuan/erban/ui/im/fragment/MessageFragment.java index ae2b97d34..ea8b07f34 100644 --- a/app/src/main/java/com/yizhuan/erban/ui/im/fragment/MessageFragment.java +++ b/app/src/main/java/com/yizhuan/erban/ui/im/fragment/MessageFragment.java @@ -3,20 +3,32 @@ package com.yizhuan.erban.ui.im.fragment; import android.Manifest; import android.annotation.SuppressLint; import android.content.Intent; +import android.graphics.Color; import android.media.AudioManager; import android.net.Uri; import android.os.Bundle; + +import androidx.annotation.NonNull; +import androidx.core.content.ContextCompat; import androidx.recyclerview.widget.LinearLayoutManager; import androidx.recyclerview.widget.RecyclerView; + +import android.text.SpannableString; +import android.text.Spanned; import android.text.TextUtils; +import android.text.method.LinkMovementMethod; +import android.text.style.ClickableSpan; +import android.text.style.ForegroundColorSpan; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.FrameLayout; +import android.widget.TextView; import com.alibaba.fastjson.JSON; +import com.alibaba.security.biometrics.build.G; import com.coorchice.library.utils.LogUtils; import com.google.gson.Gson; import com.netease.nim.uikit.api.UIKitOptions; @@ -56,13 +68,16 @@ import com.yizhuan.erban.R; import com.yizhuan.erban.avroom.game.GameSelectDialog; import com.yizhuan.erban.avroom.game.PlayGameActivity; import com.yizhuan.erban.bindadapter.BaseAdapter; +import com.yizhuan.erban.common.widget.OriginalDrawStatusClickSpan; import com.yizhuan.erban.event.MessageSizeEvent; import com.yizhuan.erban.ui.im.GreetPresenter; import com.yizhuan.erban.ui.im.MessageListPanelEx; import com.yizhuan.erban.ui.im.avtivity.NimP2PMessageActivity; import com.yizhuan.erban.ui.im.chat.MVHChatterBoxStart; import com.yizhuan.erban.ui.im.model.IMCustomModel; +import com.yizhuan.erban.ui.webview.CommonWebViewActivity; import com.yizhuan.erban.utils.PushMessageHandler; +import com.yizhuan.xchat_android_core.UriProvider; import com.yizhuan.xchat_android_core.auth.AuthModel; import com.yizhuan.xchat_android_core.im.chatterbox.ChatterBoxHelper; import com.yizhuan.xchat_android_core.im.chatterbox.HideInputEvent; @@ -137,6 +152,7 @@ public class MessageFragment extends TFragment implements ModuleProxy, MessageLi private RecyclerView recyclerView; private RxPermissions rxPermissions; + private TextView tvChatLimit; // private int limitLevel; // private int currentLevel; @@ -160,6 +176,7 @@ public class MessageFragment extends TFragment implements ModuleProxy, MessageLi } private void initView() { + tvChatLimit = rootView.findViewById(R.id.tv_chat_limit); if (!ImGameMode.gameSwitch || MarketVerifyModel.get().isMarketChecking()) { rootView.findViewById(R.id.iv_game).setVisibility(View.GONE); } @@ -185,6 +202,8 @@ public class MessageFragment extends TFragment implements ModuleProxy, MessageLi } + + private void initUserLikeGame() { boolean aBoolean = getArguments().getBoolean(NimP2PMessageActivity.IS_BY_MATCH, false); if (aBoolean) { @@ -769,6 +788,7 @@ public class MessageFragment extends TFragment implements ModuleProxy, MessageLi public void onReloadInputPanel(MessageSizeEvent event) { if (inputPanel != null) { if (event.getSize() > 0){ + tvChatLimit.setVisibility(View.GONE); inputPanel.setLimitLevel(true,""); }else { IMCustomModel.get().getPrivateChatLimit().subscribe(((privateChatLimitInfo, throwable) -> { @@ -776,8 +796,42 @@ public class MessageFragment extends TFragment implements ModuleProxy, MessageLi throwable.printStackTrace(); } else { isChat = privateChatLimitInfo.isChat(); - hintText = privateChatLimitInfo.getMessage(); + hintText = "暂无权利发起私聊"; inputPanel.setLimitLevel(privateChatLimitInfo.isChat(), privateChatLimitInfo.getMessage()); + + String experLevel = "财富等级≥"+privateChatLimitInfo.getWealthLevel(); + String charmLevel = "魅力等级≥" + privateChatLimitInfo.getCharmLevel(); + String privacyAgreementDescTip = getContext().getString(R.string.text_chat_limit, experLevel, charmLevel); + SpannableString ss = new SpannableString(privacyAgreementDescTip); + int experLevelIndex = privacyAgreementDescTip.indexOf(experLevel); + int charmLevelIndex = privacyAgreementDescTip.indexOf(charmLevel); + + + ss.setSpan(new ForegroundColorSpan(ContextCompat.getColor(getContext(), R.color.appColor)), experLevelIndex, experLevelIndex + experLevel.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); + ss.setSpan(new OriginalDrawStatusClickSpan(ContextCompat.getColor(getContext(), R.color.appColor)) { + @Override + public void onClick(@NonNull View widget) { + if (widget instanceof TextView) + ((TextView) widget).setHighlightColor(getResources().getColor(android.R.color.transparent)); + + CommonWebViewActivity.start(getContext(), UriProvider.getUserLevelUrl()); + } + }, experLevelIndex, experLevelIndex + experLevel.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); + ss.setSpan(new ForegroundColorSpan(ContextCompat.getColor(getContext(), R.color.appColor)), charmLevelIndex, charmLevelIndex + charmLevel.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); + ss.setSpan(new OriginalDrawStatusClickSpan(ContextCompat.getColor(getContext(), R.color.appColor)) { + @Override + public void onClick(@NonNull View widget) { + if (widget instanceof TextView) + ((TextView) widget).setHighlightColor(getResources().getColor(android.R.color.transparent)); + + CommonWebViewActivity.start(getContext(), UriProvider.getUserLevelUrl()); + } + }, charmLevelIndex, charmLevelIndex + experLevel.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); + + tvChatLimit.setText(ss); + tvChatLimit.setHighlightColor(Color.TRANSPARENT); + tvChatLimit.setMovementMethod(new LinkMovementMethod()); + tvChatLimit.setVisibility(View.VISIBLE); } })); } diff --git a/app/src/main/res/drawable/bg_chat_limit.xml b/app/src/main/res/drawable/bg_chat_limit.xml new file mode 100644 index 000000000..ddd7162a0 --- /dev/null +++ b/app/src/main/res/drawable/bg_chat_limit.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index dbe099798..3b3a6699e 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -100,6 +100,8 @@ 设置 实名认证 + 仅%s或%s的用于可发起聊天 + 房主已下线 更多好玩的房间在66星球等您哟!去看看! 主页 diff --git a/app/src/module_public_chat_hall/res/layout/nim_msg_fragment.xml b/app/src/module_public_chat_hall/res/layout/nim_msg_fragment.xml index 3442789a5..c1055ab47 100644 --- a/app/src/module_public_chat_hall/res/layout/nim_msg_fragment.xml +++ b/app/src/module_public_chat_hall/res/layout/nim_msg_fragment.xml @@ -46,6 +46,8 @@ android:layout_marginTop="55dp" /> + + +