Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
YDL-Component-Medical
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
杨凯
YDL-Component-Medical
Commits
44c7b91a
Commit
44c7b91a
authored
May 08, 2021
by
刘鹏
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat: 1.阿里云忽略埋点接口,2.复联站内信和聊天完成
parent
3afb39e5
Hide whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
520 additions
and
152 deletions
+520
-152
ImConstants.kt
m-im/src/main/java/com/yidianling/im/config/constants/ImConstants.kt
+9
-5
ImRetrofitApi.kt
m-im/src/main/java/com/yidianling/im/http/ImRetrofitApi.kt
+10
-0
SessionHelper.java
m-im/src/main/java/com/yidianling/im/session/SessionHelper.java
+1
-1
CustomAttachmentConfirmOrder.java
m-im/src/main/java/com/yidianling/im/session/extension/CustomAttachmentConfirmOrder.java
+29
-18
MsgViewHolderConfirmOrder.java
m-im/src/main/java/com/yidianling/im/session/viewholder/MsgViewHolderConfirmOrder.java
+135
-14
MsgViewHolderOrderAlreadyDone.java
m-im/src/main/java/com/yidianling/im/session/viewholder/MsgViewHolderOrderAlreadyDone.java
+133
-13
OtherMsgDetailActivity.java
m-im/src/main/java/com/yidianling/im/ui/activity/OtherMsgDetailActivity.java
+12
-8
MsgListAdapter.java
m-im/src/main/java/com/yidianling/im/ui/adapter/MsgListAdapter.java
+25
-7
ChatFragment.kt
m-im/src/main/java/com/yidianling/im/ui/page/fragment/ChatFragment.kt
+73
-52
NoticeFragment.kt
m-im/src/main/java/com/yidianling/im/ui/page/fragment/NoticeFragment.kt
+0
-2
NoticeAdapter.kt
m-im/src/main/java/com/yidianling/im/ui/page/fragment/adapter/NoticeAdapter.kt
+2
-1
NoticeItemBean.kt
m-im/src/main/java/com/yidianling/im/ui/page/fragment/bean/NoticeItemBean.kt
+5
-2
NoticeItemView.kt
m-im/src/main/java/com/yidianling/im/ui/page/fragment/view/NoticeItemView.kt
+1
-0
MsgViewHolderBase.java
m-im/src/main/java/com/yidianling/uikit/business/session/viewholder/MsgViewHolderBase.java
+1
-0
ServiceApi.kt
m-im/src/main/java/com/yidianling/uikit/custom/http/ServiceApi.kt
+1
-1
bg_radius_gray_linear_12.xml
m-im/src/main/res/drawable/bg_radius_gray_linear_12.xml
+11
-0
bg_radius_green_linear_12.xml
m-im/src/main/res/drawable/bg_radius_green_linear_12.xml
+11
-0
im_ui_message_custom_confirm_order.xml
m-im/src/main/res/layout/im_ui_message_custom_confirm_order.xml
+42
-27
im_ui_message_custom_order_alreadydone.xml
m-im/src/main/res/layout/im_ui_message_custom_order_alreadydone.xml
+15
-0
HttpConfig.kt
ydl-platform/src/main/java/com/ydl/ydlcommon/base/config/HttpConfig.kt
+4
-1
No files found.
m-im/src/main/java/com/yidianling/im/config/constants/ImConstants.kt
View file @
44c7b91a
...
...
@@ -8,10 +8,10 @@ class ImConstants {
val
YYPJ
=
HttpConfig
.
H5_URL
+
"comment/"
//聆听者主页
val
YTZDETAIL
=
HttpConfig
.
MH5_URL
+
"experts/"
val
YTZDETAIL
=
HttpConfig
.
MH5_URL
+
"experts/"
//用户私聊视频h5介绍
val
H5VIDEO_INFO
=
HttpConfig
.
H5_URL
+
"ex-help/76"
val
H5VIDEO_INFO
=
HttpConfig
.
H5_URL
+
"ex-help/76"
const
val
HTTP_CODE_UNLOGIN
=
100005
const
val
SILENCED_CODE
=
1000020
...
...
@@ -20,10 +20,14 @@ class ImConstants {
const
val
PAGE_SIZE
=
20
//我的微问诊记录
val
MY_CHAT
=
HttpConfig
.
H5_URL
+
"consult/my-chat"
val
MY_CHAT
=
HttpConfig
.
H5_URL
+
"consult/my-chat"
//免费体验订单详情
val
FREEDTAIL
=
HttpConfig
.
H5_URL
+
"consult-trial/"
val
FREEDTAIL
=
HttpConfig
.
H5_URL
+
"consult-trial/"
//免费体验订单详情 后边拼接orderid 如果没有拼""
val
ORDER_DETAIL
=
HttpConfig
.
H5_URL
+
"/wb/user/order/detail?needOrderHelperAlert=1&orderid="
const
val
BIND_PHONE_ACTION
=
"wxbind"
const
val
HELP_URL
=
"https://h2.yidianling.com/ex-help/96"
...
...
@@ -43,7 +47,7 @@ class ImConstants {
//连接倾听未绑定手机提示
const
val
TEL_BINDPHONE
=
"电话连接需要绑定手机哦~"
const
val
KEFUXIAOYI
=
"14"
const
val
KEFUXIAOYI
=
"14"
}
...
...
m-im/src/main/java/com/yidianling/im/http/ImRetrofitApi.kt
View file @
44c7b91a
...
...
@@ -106,4 +106,13 @@ interface ImRetrofitApi {
@POST
(
"lingxi/asistant/buryRedPoint"
)
@Headers
(
YDL_DOMAIN
+
YDL_DOMAIN_JAVA
)
fun
imBuryRedPoints
(
@Body
body
:
RequestBody
):
Observable
<
BaseAPIResponse
<
Any
>>
@POST
(
"/counselor/order/standardOrderServiceOperation"
)
@Headers
(
YDL_DOMAIN
+
YDL_DOMAIN_JAVA
)
fun
standardOrderServiceOperation
(
@Query
(
"id"
)
id
:
String
,
@Query
(
"status"
)
status
:
Int
):
Observable
<
BaseResponse
<
Any
>>
@POST
(
"/consult/user/order/affirmComplete"
)
@Headers
(
YDL_DOMAIN
+
YDL_DOMAIN_JAVA
)
fun
affirmComplete
(
@Query
(
"id"
)
id
:
String
):
Observable
<
BaseResponse
<
Any
>>
}
\ No newline at end of file
m-im/src/main/java/com/yidianling/im/session/SessionHelper.java
View file @
44c7b91a
...
...
@@ -452,7 +452,7 @@ public class SessionHelper {
NimUIKit
.
registerMsgItemViewHolder
(
CustomAttachmentPhoneCallSystemNotice
.
class
,
MsgViewHolderPhoneCallSystemNotice
.
class
);
//本地自定义消息
NimUIKit
.
registerMsgItemViewHolder
(
CustomSystemTips
.
class
,
MsgViewHolderSystemTips
.
class
);
//本地系统自定义消息 对应24
NimUIKit
.
registerMsgItemViewHolder
(
CustomRecommendExpertListMsg
.
class
,
MsgViewHolderRecommendExpertList
.
class
);
//推荐专家列表 对应25
NimUIKit
.
registerMsgItemViewHolder
(
CustomAttachConsultSubScript
.
class
,
MsgViewHolderConsultSubScribe
.
class
);
//确认咨询预约消息
NimUIKit
.
registerMsgItemViewHolder
(
CustomAttachConsultSubScript
.
class
,
MsgViewHolderConsultSubScribe
.
class
);
//确认咨询预约消息
27
NimUIKit
.
registerMsgItemViewHolder
(
CustomAttachConsultPerfectData
.
class
,
MsgViewHolderPerfectConsultData
.
class
);
//完善咨询资料提醒消息
NimUIKit
.
registerMsgItemViewHolder
(
CustomAttachPleaseSubscribeConsultDate
.
class
,
MsgViewHolderPleaseSubscribeConsultDate
.
class
);
//请预约咨询时间
NimUIKit
.
registerMsgItemViewHolder
(
CustomCustomerServiceCardAttachment
.
class
,
MsgViewHolderCustomerServiceCard
.
class
);
//客服小壹名片
...
...
m-im/src/main/java/com/yidianling/im/session/extension/CustomAttachmentConfirmOrder.java
View file @
44c7b91a
...
...
@@ -2,18 +2,25 @@ package com.yidianling.im.session.extension;
import
com.alibaba.fastjson.JSONObject
;
public
class
CustomAttachmentConfirmOrder
extends
CustomAttachment
{
private
static
final
String
TITLE
=
"title"
;
//标题
private
static
final
String
STATUS
=
"status"
;
//状态,1代表已确认,0代表待确认
private
static
final
String
BOOKINGTIME
=
"bookingTime"
;
///咨询时间
private
static
final
String
SERVICETYPE
=
"serviceType"
;
//服务方式
private
static
final
String
ORDERID
=
"orderId"
;
//订单号
public
class
CustomAttachmentConfirmOrder
extends
CustomAttachment
{
private
static
final
String
TITLE
=
"title"
;
//标题
private
static
final
String
STATUS
=
"status"
;
//状态,1代表已确认,0代表待确认
private
static
final
String
BOOKINGTIME
=
"bookingTime"
;
///咨询时间
private
static
final
String
SERVICETYPE
=
"serviceType"
;
//服务方式
private
static
final
String
ORDERID
=
"orderId"
;
//订单号
private
static
final
String
NEWSORDERID
=
"newsOrderId"
;
//用于跳转新版订单详情
private
static
final
String
URL
=
"url"
;
//跳转链接
public
String
title
;
public
String
status
;
public
String
bookingtime
;
public
String
servicetype
;
public
Long
orderid
;
public
String
consultDuration
;
public
String
bookingTime
;
public
String
title
;
public
String
productName
;
public
String
url
;
public
String
orderId
;
public
String
newsOrderId
;
public
String
serviceId
;
public
int
status
;
CustomAttachmentConfirmOrder
()
{
super
(
CustomAttachmentType
.
TYPE_CONFIRM_ORDER
);
...
...
@@ -22,21 +29,25 @@ public class CustomAttachmentConfirmOrder extends CustomAttachment{
@Override
protected
void
parseData
(
JSONObject
data
)
{
this
.
title
=
data
.
getString
(
TITLE
);
this
.
status
=
data
.
getString
(
STATUS
);
this
.
bookingtime
=
data
.
getString
(
BOOKINGTIME
);
this
.
servicetype
=
data
.
getString
(
SERVICETYPE
);
this
.
orderid
=
data
.
getLong
(
ORDERID
);
this
.
title
=
data
.
getString
(
TITLE
);
this
.
status
=
data
.
getInteger
(
STATUS
);
this
.
bookingTime
=
data
.
getString
(
BOOKINGTIME
);
this
.
servicetype
=
data
.
getString
(
SERVICETYPE
);
this
.
orderId
=
data
.
getString
(
ORDERID
);
this
.
newsOrderId
=
data
.
getString
(
NEWSORDERID
);
this
.
url
=
data
.
getString
(
URL
);
}
@Override
protected
JSONObject
packData
()
{
JSONObject
data
=
new
JSONObject
();
data
.
put
(
TITLE
,
title
);
data
.
put
(
TITLE
,
title
);
data
.
put
(
STATUS
,
status
);
data
.
put
(
BOOKINGTIME
,
booking
t
ime
);
data
.
put
(
BOOKINGTIME
,
booking
T
ime
);
data
.
put
(
SERVICETYPE
,
servicetype
);
data
.
put
(
ORDERID
,
orderid
);
data
.
put
(
ORDERID
,
orderId
);
data
.
put
(
NEWSORDERID
,
newsOrderId
);
data
.
put
(
URL
,
url
);
return
data
;
}
}
m-im/src/main/java/com/yidianling/im/session/viewholder/MsgViewHolderConfirmOrder.java
View file @
44c7b91a
...
...
@@ -8,23 +8,44 @@ import android.widget.TextView;
import
androidx.core.content.ContextCompat
;
import
com.netease.nimlib.sdk.NIMClient
;
import
com.netease.nimlib.sdk.RequestCallback
;
import
com.netease.nimlib.sdk.msg.MsgService
;
import
com.netease.nimlib.sdk.msg.attachment.MsgAttachment
;
import
com.netease.nimlib.sdk.msg.constant.SessionTypeEnum
;
import
com.netease.nimlib.sdk.msg.model.IMMessage
;
import
com.ydl.webview.H5Params
;
import
com.ydl.webview.NewH5Activity
;
import
com.ydl.ydlcommon.data.http.RxUtils
;
import
com.ydl.ydlcommon.utils.remind.HttpErrorUtils
;
import
com.yidianling.common.tools.ToastUtil
;
import
com.yidianling.im.R
;
import
com.yidianling.im.session.extension.CustomAttachConsultSubScript
;
import
com.yidianling.im.config.constants.ImConstants
;
import
com.yidianling.im.http.ImRetrofitApi
;
import
com.yidianling.im.session.extension.CustomAttachmentConfirmOrder
;
import
com.yidianling.nimbase.common.ui.recyclerview.adapter.BaseMultiItemFetchLoadAdapter
;
import
com.yidianling.uikit.business.session.viewholder.MsgViewHolderBase
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
io.reactivex.android.schedulers.AndroidSchedulers
;
import
io.reactivex.schedulers.Schedulers
;
public
class
MsgViewHolderConfirmOrder
extends
MsgViewHolderBase
{
private
TextView
tv_title
,
tv_date
,
tv_type
;
private
TextView
tv_title
,
tv_date
,
tv_type
,
tv_submit
;
private
View
lin_root
;
private
ImageView
img_icon
;
public
String
url
;
//跳转url
public
int
flag
;
//0 未确认 1已确认
/***跳转url*/
public
String
url
;
/***新订单id*/
public
String
newsOrderId
;
/***订单id*/
public
String
orderId
;
/***0 未确认 1已确认*/
public
int
flag
;
public
MsgViewHolderConfirmOrder
(
BaseMultiItemFetchLoadAdapter
adapter
)
{
super
(
adapter
);
...
...
@@ -42,11 +63,12 @@ public class MsgViewHolderConfirmOrder extends MsgViewHolderBase {
tv_type
=
view
.
findViewById
(
R
.
id
.
tv_type
);
lin_root
=
view
.
findViewById
(
R
.
id
.
lin_root
);
img_icon
=
view
.
findViewById
(
R
.
id
.
img_icon
);
tv_submit
=
view
.
findViewById
(
R
.
id
.
tv_submit
);
if
(
isReceivedMessage
()){
if
(
isReceivedMessage
())
{
setAvatarRightInVisibity
();
lin_root
.
setBackgroundResource
(
R
.
drawable
.
im_bg_radius_no_topleft_white_8
);
}
else
{
}
else
{
setAvatarLeftInVisibity
();
lin_root
.
setBackgroundResource
(
R
.
drawable
.
im_bg_radius_no_topright_white_8
);
}
...
...
@@ -55,25 +77,124 @@ public class MsgViewHolderConfirmOrder extends MsgViewHolderBase {
@SuppressLint
(
"SetTextI18n"
)
@Override
protected
void
bindContentView
()
{
if
(
isReceivedMessage
()){
if
(
isReceivedMessage
())
{
setAvatarRightInVisibity
();
}
else
{
}
else
{
setAvatarLeftInVisibity
();
}
MsgAttachment
attachment
=
message
.
getAttachment
();
if
(
attachment
instanceof
CustomAttachmentConfirmOrder
)
{
tv_title
.
setText
(((
CustomAttachmentConfirmOrder
)
attachment
).
title
);
tv_date
.
setText
(
"咨询时间:"
+((
CustomAttachmentConfirmOrder
)
attachment
).
bookingtime
);
tv_type
.
setText
(
"服务方式:"
+((
CustomAttachmentConfirmOrder
)
attachment
).
servicetype
);
CustomAttachmentConfirmOrder
customAttachment
=
(
CustomAttachmentConfirmOrder
)
attachment
;
tv_title
.
setText
(
customAttachment
.
title
);
tv_date
.
setText
(
"咨询时间:"
+
customAttachment
.
bookingTime
);
tv_type
.
setText
(
"服务方式:"
+
customAttachment
.
servicetype
);
url
=
customAttachment
.
url
;
newsOrderId
=
customAttachment
.
newsOrderId
;
orderId
=
customAttachment
.
orderId
;
flag
=
customAttachment
.
status
;
if
(
flag
==
1
)
{
// 1代表已确认,0代表待确认
tv_submit
.
setText
(
"已确认"
);
tv_submit
.
setEnabled
(
false
);
tv_submit
.
setBackground
(
ContextCompat
.
getDrawable
(
context
,
R
.
drawable
.
bg_radius_gray_linear_12
));
img_icon
.
setVisibility
(
View
.
VISIBLE
);
tv_submit
.
setVisibility
(
View
.
GONE
);
}
else
{
tv_submit
.
setText
(
"确认"
);
tv_submit
.
setEnabled
(
true
);
tv_submit
.
setBackground
(
ContextCompat
.
getDrawable
(
context
,
R
.
drawable
.
bg_radius_green_linear_12
));
img_icon
.
setVisibility
(
View
.
GONE
);
tv_submit
.
setVisibility
(
View
.
VISIBLE
);
}
tv_submit
.
setOnClickListener
(
v
->
{
//确定按钮给服务端发消息发送
//确认接口
ToastUtil
.
toastShort
(
context
,
"发送中..."
);
ImRetrofitApi
.
Companion
.
getImRetrofitApi
().
standardOrderServiceOperation
(
orderId
,
flag
)
.
subscribeOn
(
Schedulers
.
io
())
.
compose
(
RxUtils
.
INSTANCE
.
resultData
())
.
observeOn
(
AndroidSchedulers
.
mainThread
())
.
subscribe
(
it
->
{
//确认完成,按钮置灰,更新本地消息
updateLocalMsg
();
},
throwable
->
HttpErrorUtils
.
Companion
.
handleError
(
context
,
throwable
));
});
}
hideItemBg
();
}
@Override
protected
void
onItemClick
()
{
if
(
TextUtils
.
isEmpty
(
url
)){
if
(
TextUtils
.
isEmpty
(
url
))
{
return
;
}
NewH5Activity
.
start
(
context
,
new
H5Params
(
url
,
null
));
if
(
newsOrderId
==
null
||
newsOrderId
.
isEmpty
())
{
NewH5Activity
.
start
(
context
,
new
H5Params
(
url
,
null
));
}
else
{
//跳转新订单详情页
H5Params
orderParams
=
new
H5Params
(
ImConstants
.
Companion
.
getORDER_DETAIL
()
+
(
newsOrderId
.
isEmpty
()
?
""
:
newsOrderId
),
null
);
NewH5Activity
.
start
(
context
,
orderParams
);
}
}
private
void
updateLocalMsg
()
{
updateSureView
(
"已确认"
);
//更新本地消息
Map
<
String
,
Object
>
map
=
message
.
getLocalExtension
();
if
(
map
==
null
)
{
map
=
new
HashMap
();
}
map
.
put
(
"isSure"
,
true
);
message
.
setLocalExtension
(
map
);
NIMClient
.
getService
(
MsgService
.
class
).
updateIMMessage
(
message
);
//同时更新历史同订单未确认的消息状态
NIMClient
.
getService
(
MsgService
.
class
).
queryMessageList
(
message
.
getFromAccount
(),
SessionTypeEnum
.
P2P
,
0
,
100
).
setCallback
(
new
RequestCallback
<
List
<
IMMessage
>>()
{
@Override
public
void
onSuccess
(
List
<
IMMessage
>
param
)
{
if
(
param
!=
null
&&
param
.
size
()
>
0
)
{
for
(
IMMessage
msg
:
param
)
{
MsgAttachment
attachment
=
msg
.
getAttachment
();
if
(
attachment
instanceof
CustomAttachmentConfirmOrder
)
{
CustomAttachmentConfirmOrder
customAttachConsultSubScript
=
(
CustomAttachmentConfirmOrder
)
attachment
;
if
(
customAttachConsultSubScript
.
orderId
.
equals
(
orderId
))
{
//修改历史消息状态为已失效
Map
map1
=
msg
.
getLocalExtension
();
if
(
map1
==
null
)
{
map1
=
new
HashMap
();
map1
.
put
(
"isExpired"
,
true
);
msg
.
setLocalExtension
(
map1
);
NIMClient
.
getService
(
MsgService
.
class
).
updateIMMessage
(
msg
);
}
}
}
}
}
}
@Override
public
void
onFailed
(
int
code
)
{
}
@Override
public
void
onException
(
Throwable
exception
)
{
}
});
}
private
void
updateSureView
(
String
btnName
)
{
tv_submit
.
setText
(
btnName
);
tv_submit
.
setEnabled
(
false
);
tv_submit
.
setBackground
(
ContextCompat
.
getDrawable
(
context
,
R
.
drawable
.
bg_radius_gray_linear_12
));
}
}
m-im/src/main/java/com/yidianling/im/session/viewholder/MsgViewHolderOrderAlreadyDone.java
View file @
44c7b91a
...
...
@@ -8,23 +8,45 @@ import android.widget.TextView;
import
androidx.core.content.ContextCompat
;
import
com.netease.nimlib.sdk.NIMClient
;
import
com.netease.nimlib.sdk.RequestCallback
;
import
com.netease.nimlib.sdk.msg.MsgService
;
import
com.netease.nimlib.sdk.msg.attachment.MsgAttachment
;
import
com.netease.nimlib.sdk.msg.constant.SessionTypeEnum
;
import
com.netease.nimlib.sdk.msg.model.IMMessage
;
import
com.ydl.webview.H5Params
;
import
com.ydl.webview.NewH5Activity
;
import
com.ydl.ydlcommon.data.http.RxUtils
;
import
com.ydl.ydlcommon.utils.remind.HttpErrorUtils
;
import
com.yidianling.common.tools.ToastUtil
;
import
com.yidianling.im.R
;
import
com.yidianling.im.session.extension.CustomAttachConsultSubScript
;
import
com.yidianling.im.config.constants.ImConstants
;
import
com.yidianling.im.http.ImRetrofitApi
;
import
com.yidianling.im.session.extension.CustomAttachmentConfirmOrder
;
import
com.yidianling.nimbase.common.ui.recyclerview.adapter.BaseMultiItemFetchLoadAdapter
;
import
com.yidianling.uikit.business.session.viewholder.MsgViewHolderBase
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
io.reactivex.android.schedulers.AndroidSchedulers
;
import
io.reactivex.schedulers.Schedulers
;
public
class
MsgViewHolderOrderAlreadyDone
extends
MsgViewHolderBase
{
private
TextView
tv_title
,
tv_date
,
tv_type
;
private
TextView
tv_title
,
tv_date
,
tv_type
,
tv_submit
;
private
View
lin_root
;
private
ImageView
img_icon
;
public
String
url
;
//跳转url
public
int
flag
;
//0 未确认 1已确认
/***跳转url*/
public
String
url
;
/***新订单id*/
public
String
newsOrderId
;
/***订单id*/
public
String
orderId
;
/***0 未确认 1已确认*/
public
int
flag
;
public
MsgViewHolderOrderAlreadyDone
(
BaseMultiItemFetchLoadAdapter
adapter
)
{
super
(
adapter
);
...
...
@@ -42,11 +64,12 @@ public class MsgViewHolderOrderAlreadyDone extends MsgViewHolderBase {
tv_type
=
view
.
findViewById
(
R
.
id
.
tv_type
);
lin_root
=
view
.
findViewById
(
R
.
id
.
lin_root
);
img_icon
=
view
.
findViewById
(
R
.
id
.
img_icon
);
tv_submit
=
view
.
findViewById
(
R
.
id
.
tv_submit
);
if
(
isReceivedMessage
()){
if
(
isReceivedMessage
())
{
setAvatarRightInVisibity
();
lin_root
.
setBackgroundResource
(
R
.
drawable
.
im_bg_radius_no_topleft_white_8
);
}
else
{
}
else
{
setAvatarLeftInVisibity
();
lin_root
.
setBackgroundResource
(
R
.
drawable
.
im_bg_radius_no_topright_white_8
);
}
...
...
@@ -55,25 +78,122 @@ public class MsgViewHolderOrderAlreadyDone extends MsgViewHolderBase {
@SuppressLint
(
"SetTextI18n"
)
@Override
protected
void
bindContentView
()
{
if
(
isReceivedMessage
()){
if
(
isReceivedMessage
())
{
setAvatarRightInVisibity
();
}
else
{
}
else
{
setAvatarLeftInVisibity
();
}
MsgAttachment
attachment
=
message
.
getAttachment
();
if
(
attachment
instanceof
CustomAttachmentConfirmOrder
)
{
tv_title
.
setText
(((
CustomAttachmentConfirmOrder
)
attachment
).
title
);
tv_date
.
setText
(
"咨询时间:"
+((
CustomAttachmentConfirmOrder
)
attachment
).
bookingtime
);
tv_type
.
setText
(
"服务方式:"
+((
CustomAttachmentConfirmOrder
)
attachment
).
servicetype
);
CustomAttachmentConfirmOrder
customAttachment
=
(
CustomAttachmentConfirmOrder
)
attachment
;
tv_title
.
setText
(
customAttachment
.
title
);
tv_date
.
setText
(
"咨询时间:"
+
(
customAttachment
.
bookingTime
));
tv_type
.
setText
(
"服务方式:"
+
(
customAttachment
.
servicetype
));
url
=
customAttachment
.
url
;
newsOrderId
=
customAttachment
.
newsOrderId
;
orderId
=
customAttachment
.
orderId
;
flag
=
customAttachment
.
status
;
if
(
flag
==
1
)
{
// 1代表已确认,0代表待确认
tv_submit
.
setText
(
"已确认"
);
tv_submit
.
setEnabled
(
false
);
tv_submit
.
setBackground
(
ContextCompat
.
getDrawable
(
context
,
R
.
drawable
.
bg_radius_gray_linear_12
));
img_icon
.
setVisibility
(
View
.
VISIBLE
);
tv_submit
.
setVisibility
(
View
.
GONE
);
}
else
{
tv_submit
.
setText
(
"确认"
);
tv_submit
.
setEnabled
(
true
);
tv_submit
.
setBackground
(
ContextCompat
.
getDrawable
(
context
,
R
.
drawable
.
bg_radius_green_linear_12
));
img_icon
.
setVisibility
(
View
.
GONE
);
tv_submit
.
setVisibility
(
View
.
VISIBLE
);
}
tv_submit
.
setOnClickListener
(
v
->
{
//确定按钮给服务端发消息发送
//确认接口
ToastUtil
.
toastShort
(
context
,
"发送中..."
);
ImRetrofitApi
.
Companion
.
getImRetrofitApi
().
affirmComplete
(
orderId
)
.
subscribeOn
(
Schedulers
.
io
())
.
compose
(
RxUtils
.
INSTANCE
.
resultData
())
.
observeOn
(
AndroidSchedulers
.
mainThread
())
.
subscribe
(
it
->
{
//确认完成,按钮置灰,更新本地消息
updateLocalMsg
();
},
throwable
->
HttpErrorUtils
.
Companion
.
handleError
(
context
,
throwable
));
});
}
hideItemBg
();
}
@Override
protected
void
onItemClick
()
{
if
(
TextUtils
.
isEmpty
(
url
)){
if
(
TextUtils
.
isEmpty
(
url
))
{
return
;
}
NewH5Activity
.
start
(
context
,
new
H5Params
(
url
,
null
));
if
(
newsOrderId
==
null
||
newsOrderId
.
isEmpty
())
{
NewH5Activity
.
start
(
context
,
new
H5Params
(
url
,
null
));
}
else
{
//跳转新订单详情页
H5Params
orderParams
=
new
H5Params
(
ImConstants
.
Companion
.
getORDER_DETAIL
()
+
(
newsOrderId
.
isEmpty
()
?
""
:
newsOrderId
),
null
);
NewH5Activity
.
start
(
context
,
orderParams
);
}
}
private
void
updateLocalMsg
()
{
updateSureView
(
"已确认"
);
//更新本地消息
Map
<
String
,
Object
>
map
=
message
.
getLocalExtension
();
if
(
map
==
null
)
{
map
=
new
HashMap
();
}
map
.
put
(
"isSure"
,
true
);
message
.
setLocalExtension
(
map
);
NIMClient
.
getService
(
MsgService
.
class
).
updateIMMessage
(
message
);
//同时更新历史同订单未确认的消息状态
NIMClient
.
getService
(
MsgService
.
class
).
queryMessageList
(
message
.
getFromAccount
(),
SessionTypeEnum
.
P2P
,
0
,
100
).
setCallback
(
new
RequestCallback
<
List
<
IMMessage
>>()
{
@Override
public
void
onSuccess
(
List
<
IMMessage
>
param
)
{
if
(
param
!=
null
&&
param
.
size
()
>
0
)
{
for
(
IMMessage
msg
:
param
)
{
MsgAttachment
attachment
=
msg
.
getAttachment
();
if
(
attachment
instanceof
CustomAttachmentConfirmOrder
)
{
CustomAttachmentConfirmOrder
customAttachConsultSubScript
=
(
CustomAttachmentConfirmOrder
)
attachment
;
if
(
customAttachConsultSubScript
.
orderId
.
equals
(
orderId
))
{
//修改历史消息状态为已失效
Map
map1
=
msg
.
getLocalExtension
();
if
(
map1
==
null
)
{
map1
=
new
HashMap
();
map1
.
put
(
"isExpired"
,
true
);
msg
.
setLocalExtension
(
map1
);
NIMClient
.
getService
(
MsgService
.
class
).
updateIMMessage
(
msg
);
}
}
}
}
}
}
@Override
public
void
onFailed
(
int
code
)
{
}
@Override
public
void
onException
(
Throwable
exception
)
{
}
});
}
private
void
updateSureView
(
String
btnName
)
{
tv_submit
.
setText
(
btnName
);
tv_submit
.
setEnabled
(
false
);
tv_submit
.
setBackground
(
ContextCompat
.
getDrawable
(
context
,
R
.
drawable
.
bg_radius_gray_linear_12
));
}
}
m-im/src/main/java/com/yidianling/im/ui/activity/OtherMsgDetailActivity.java
View file @
44c7b91a
...
...
@@ -37,7 +37,7 @@ import io.reactivex.disposables.Disposable;
/**
* 动态消息列表
*/
public
class
OtherMsgDetailActivity
extends
BaseActivity
implements
PtrHandler
{
public
class
OtherMsgDetailActivity
extends
BaseActivity
implements
PtrHandler
{
String
title
=
""
;
...
...
@@ -48,13 +48,14 @@ public class OtherMsgDetailActivity extends BaseActivity implements PtrHandler{
TitleBar
titlebar
;
MsgListAdapter
adapter
;
int
type
;
//消息类别
//消息类别
int
type
;
int
page
=
0
;
boolean
hasMore
=
true
;
List
<
MsgData
>
msgDatas
;
@Override
protected
int
layoutResId
()
{
return
R
.
layout
.
im_activity_other_msg_detail
;
...
...
@@ -75,14 +76,15 @@ public class OtherMsgDetailActivity extends BaseActivity implements PtrHandler{
@NotNull
@Override
public
StatusBarOptions
getStatusViewOptions
()
{
return
new
StatusBarOptions
(
true
,
true
);
return
new
StatusBarOptions
(
true
,
true
);
}
void
init
()
{
if
(
title
!=
null
&&
!
title
.
equals
(
""
))
{
titlebar
.
setTitle
(
title
);
}
if
(
type
==
14
)
{
//反馈页面
//反馈页面
if
(
type
==
14
)
{
titlebar
.
setTitle
(
"通知"
);
titlebar
.
setmRightText
(
"投诉反馈"
);
}
...
...
@@ -107,7 +109,7 @@ public class OtherMsgDetailActivity extends BaseActivity implements PtrHandler{
store_house_ptr_frame
.
setPtrHandler
(
this
);
store_house_ptr_frame
.
addPtrUIHandler
(
header
);
adapter
=
new
MsgListAdapter
(
this
,
type
,
this
);
adapter
=
new
MsgListAdapter
(
this
,
type
,
this
);
lv_content
.
setAdapter
(
adapter
);
lv_content
.
setEmptyView
(
ll_empty
);
...
...
@@ -148,14 +150,16 @@ public class OtherMsgDetailActivity extends BaseActivity implements PtrHandler{
page
=
1
;
}
Disposable
dis
=
httpHelper
.
getMsgList
(
new
MsgListParam
(
page
+
""
,
type
))
Disposable
dis
=
httpHelper
.
getMsgList
(
new
MsgListParam
(
page
+
""
,
type
))
.
compose
(
RxUtils
.
applySchedulers
(
this
))
.
compose
(
RxUtils
.
resultData
())
.
subscribe
(
msgData
->
{
LogUtil
.
d
(
"data fetch compelete"
);
store_house_ptr_frame
.
refreshComplete
();
msgDatas
=
msgData
;
if
(
msgDatas
.
size
()
==
0
)
return
;
if
(
msgDatas
.
size
()
==
0
)
{
return
;
}
if
(
msgDatas
==
null
||
msgDatas
.
size
()
<
ImConstants
.
PAGE_SIZE
)
{
hasMore
=
false
;
}
...
...
m-im/src/main/java/com/yidianling/im/ui/adapter/MsgListAdapter.java
View file @
44c7b91a
...
...
@@ -13,7 +13,6 @@ import com.ydl.ydlcommon.base.BaseActivity;
import
com.ydl.ydlcommon.base.lifecycle.ILifecycleable
;
import
com.ydl.ydlcommon.data.http.RxUtils
;
import
com.ydl.ydlcommon.data.http.ThrowableConsumer
;
import
com.ydl.ydlcommon.utils.LogUtil
;
import
com.ydl.ydlcommon.utils.StringUtils
;
import
com.ydl.ydlcommon.utils.remind.ToastHelper
;
import
com.yidianling.im.bean.MsgData
;
...
...
@@ -41,7 +40,8 @@ import io.reactivex.schedulers.Schedulers;
public
class
MsgListAdapter
extends
CommonAdapter
<
MsgData
>
{
private
ILifecycleable
lifecycleable
;
private
Activity
context
;
private
int
type
=
0
;
//消息类型
/*** 消息类型*/
private
int
type
=
0
;
public
MsgListAdapter
(
Activity
context
)
{
this
.
context
=
context
;
...
...
@@ -49,7 +49,7 @@ public class MsgListAdapter extends CommonAdapter<MsgData> {
private
ImHttp
httpHelper
;
public
MsgListAdapter
(
Activity
context
,
int
type
,
ILifecycleable
lifecycleable
)
{
public
MsgListAdapter
(
Activity
context
,
int
type
,
ILifecycleable
lifecycleable
)
{
this
.
context
=
context
;
this
.
type
=
type
;
this
.
lifecycleable
=
lifecycleable
;
...
...
@@ -108,6 +108,8 @@ public class MsgListAdapter extends CommonAdapter<MsgData> {
ARouter
.
getInstance
().
build
(
"/mine/MyFeedBackActivity"
).
withString
(
"intent_id"
,
mDataList
.
get
(
position
).
relation_id
).
navigation
();
fla
=
true
;
break
;
default
:
break
;
}
}
...
...
@@ -129,7 +131,7 @@ public class MsgListAdapter extends CommonAdapter<MsgData> {
}
});
//如果是动态消息则到此结束,其它消息类型走下面流程
}
else
{
}
else
{
Disposable
di
=
httpHelper
.
getMsgDetail
(
new
MsgDetailParam
(
mDataList
.
get
(
position
).
id
))
// .compose(RxUtils.applySchedulers(lifecycleable))
.
subscribeOn
(
Schedulers
.
io
())
...
...
@@ -159,7 +161,6 @@ public class MsgListAdapter extends CommonAdapter<MsgData> {
case
508
:
case
509
:
//预约评价 微问诊评价 倾诉评价
H5Params
h5Paramspi
=
new
H5Params
(
ImConstants
.
Companion
.
getYYPJ
()
+
msgDetail
.
relation_id1
,
null
);
NewH5Activity
.
start
(
context
,
h5Paramspi
);
break
;
...
...
@@ -175,9 +176,24 @@ public class MsgListAdapter extends CommonAdapter<MsgData> {
break
;
case
1003
:
// ImIn.INSTANCE.MyRedPackActivity(context,null);
ImIn
.
INSTANCE
.
myRedPockIntent
(
context
);
break
;
case
521
:
case
522
:
case
523
:
case
524
:
case
525
:
case
526
:
// 521-526 解忧 - 订单详情
H5Params
orderParams
=
new
H5Params
(
ImConstants
.
Companion
.
getORDER_DETAIL
()
+
(
msgDetail
.
relation_id1
.
isEmpty
()
?
""
:
msgDetail
.
relation_id1
),
null
);
NewH5Activity
.
start
(
context
,
orderParams
);
break
;
default
:
break
;
}
},
new
ThrowableConsumer
()
{
@Override
...
...
@@ -200,7 +216,9 @@ public class MsgListAdapter extends CommonAdapter<MsgData> {
notifyDataSetChanged
();
}
//根据url解析跳转
/**
* 根据url解析跳转
*/
private
boolean
jumpForUrl
(
String
url
)
{
boolean
fa
=
false
;
Map
<
String
,
String
>
map
=
StringUtils
.
IsHttpReturn
(
url
);
...
...
m-im/src/main/java/com/yidianling/im/ui/page/fragment/ChatFragment.kt
View file @
44c7b91a
...
...
@@ -2,8 +2,8 @@ package com.yidianling.im.ui.page.fragment
import
android.content.Context
import
android.graphics.Color
import
androidx.recyclerview.widget.LinearLayoutManager
import
android.view.View
import
androidx.recyclerview.widget.LinearLayoutManager
import
com.jcodecraeer.xrecyclerview.CustomFooterViewCallBack
import
com.jcodecraeer.xrecyclerview.XRecyclerView
import
com.ydl.ydlcommon.base.BaseFragment
...
...
@@ -34,12 +34,14 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
SERVICING
,
// 服务中
SERVICED
// 服务过
}
private
lateinit
var
mContext
:
Context
private
lateinit
var
mContext
:
Context
private
var
chatAdapter
:
ChatAdapter
?
=
null
private
var
allChatData
:
ChatModelBean
=
ChatModelBean
()
//全部数据
private
var
showData
:
ArrayList
<
ChatItemBean
>
=
ArrayList
()
// 最终展示的数据
private
var
threeWeekItem
:
ChatItemBean
=
ChatItemBean
(
0
,
0
,
""
,
0
,
0
,
""
,
0
,
0
,
0
,
0
,
0
,
""
,
0
,
""
,
""
,
0
,
0
,
0
,
""
,
1
,
""
,
true
)
private
var
threeWeekItem
:
ChatItemBean
=
ChatItemBean
(
0
,
0
,
""
,
0
,
0
,
""
,
0
,
0
,
0
,
0
,
0
,
""
,
0
,
""
,
""
,
0
,
0
,
0
,
""
,
1
,
""
,
true
)
private
var
mChatModelType
:
ChatModelType
=
ChatModelType
.
ALL
// 默认展示全部
...
...
@@ -80,25 +82,27 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
}
fun
getChatMessageData
()
{
var
selectType
:
Int
=
if
(
mChatModelType
==
ChatModelType
.
ALL
)
0
else
if
(
mChatModelType
==
ChatModelType
.
SERVICING
)
1
else
2
var
selectType
:
Int
=
if
(
mChatModelType
==
ChatModelType
.
ALL
)
0
else
if
(
mChatModelType
==
ChatModelType
.
SERVICING
)
1
else
2
if
(
ImIn
.
getUserInfo
()
?.
uid
!=
"0"
)
{
var
dis
=
ImHttpImpl
.
getInstance
().
getAllChatMessage
(
ChatParam
(
"${ImIn.getUserInfo()?.uid}"
,
"${selectType}"
))
.
compose
(
RxUtils
.
applySchedulers
(
this
))
.
compose
<
ChatModelBean
>(
RxUtils
.
resultJavaData
())
.
subscribe
({
it
->
if
(
it
.
before
.
data
.
size
!=
0
||
it
.
nomal
.
data
.
size
!=
0
)
{
setData
(
it
)
}
chat_recyclerview
?.
let
{
chat_recyclerview
.
refreshComplete
()
}
},
{
t
->
ToastUtil
.
toastShort
(
"您的网络出现了问题"
)
chat_recyclerview
?.
let
{
chat_recyclerview
.
refreshComplete
()
}
})
var
dis
=
ImHttpImpl
.
getInstance
()
.
getAllChatMessage
(
ChatParam
(
"${ImIn.getUserInfo()?.uid}"
,
"${selectType}"
))
.
compose
(
RxUtils
.
applySchedulers
(
this
))
.
compose
<
ChatModelBean
>(
RxUtils
.
resultJavaData
())
.
subscribe
({
it
->
if
(
it
.
before
.
data
.
size
!=
0
||
it
.
nomal
.
data
.
size
!=
0
)
{
setData
(
it
)
}
chat_recyclerview
?.
let
{
chat_recyclerview
.
refreshComplete
()
}
},
{
t
->
ToastUtil
.
toastShort
(
"您的网络出现了问题"
)
chat_recyclerview
?.
let
{
chat_recyclerview
.
refreshComplete
()
}
})
}
}
...
...
@@ -159,35 +163,44 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
// 全部
ChatModelType
.
ALL
->
{
showData
.
addAll
(
allChatData
.
topData
.
data
.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
nomal
.
data
.
filter
{
it
.
is_top
==
0
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
nomal
.
data
.
filter
{
it
.
is_top
==
0
}
.
sortedWith
(
mCompare
))
if
(
allChatData
.
before
.
data
.
any
{
it
.
is_top
==
0
})
{
showData
.
add
(
threeWeekItem
)
showData
.
addAll
(
allChatData
.
before
.
data
.
filter
{
it
.
is_top
==
0
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
before
.
data
.
filter
{
it
.
is_top
==
0
}
.
sortedWith
(
mCompare
))
}
}
// 服务中
ChatModelType
.
SERVICING
->
{
showData
.
addAll
(
allChatData
.
topData
.
data
.
filter
{
it
.
isBusy
==
1
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
nomal
.
data
.
filter
{
it
.
isBusy
==
1
&&
it
.
is_top
==
0
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
topData
.
data
.
filter
{
it
.
isBusy
==
1
}
.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
nomal
.
data
.
filter
{
it
.
isBusy
==
1
&&
it
.
is_top
==
0
}
.
sortedWith
(
mCompare
))
if
(
allChatData
.
before
.
data
.
any
{
it
.
isBusy
==
1
&&
it
.
is_top
==
0
})
{
showData
.
add
(
threeWeekItem
)
showData
.
addAll
(
allChatData
.
before
.
data
.
filter
{
it
.
isBusy
==
1
&&
it
.
is_top
==
0
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
before
.
data
.
filter
{
it
.
isBusy
==
1
&&
it
.
is_top
==
0
}
.
sortedWith
(
mCompare
))
}
}
// 服务过
ChatModelType
.
SERVICED
->
{
showData
.
addAll
(
allChatData
.
topData
.
data
.
filter
{
it
.
isBusy
!=
1
&&
it
.
orderCount
+
it
.
listenOrderCount
>
0
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
nomal
.
data
.
filter
{
it
.
isBusy
!=
1
&&
it
.
is_top
==
0
&&
(
it
.
orderCount
+
it
.
listenOrderCount
>
0
)
}.
sortedWith
(
mCompare
))
if
(
allChatData
.
before
.
data
.
any
{
it
.
isBusy
!=
1
&&
it
.
is_top
==
0
&&
(
it
.
orderCount
+
it
.
listenOrderCount
>
0
)})
{
showData
.
addAll
(
allChatData
.
topData
.
data
.
filter
{
it
.
isBusy
!=
1
&&
it
.
orderCount
+
it
.
listenOrderCount
>
0
}
.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
nomal
.
data
.
filter
{
it
.
isBusy
!=
1
&&
it
.
is_top
==
0
&&
(
it
.
orderCount
+
it
.
listenOrderCount
>
0
)
}
.
sortedWith
(
mCompare
))
if
(
allChatData
.
before
.
data
.
any
{
it
.
isBusy
!=
1
&&
it
.
is_top
==
0
&&
(
it
.
orderCount
+
it
.
listenOrderCount
>
0
)
})
{
showData
.
add
(
threeWeekItem
)
showData
.
addAll
(
allChatData
.
before
.
data
.
filter
{
it
.
isBusy
!=
1
&&
it
.
is_top
==
0
&&
(
it
.
orderCount
+
it
.
listenOrderCount
>
0
)
}.
sortedWith
(
mCompare
))
showData
.
addAll
(
allChatData
.
before
.
data
.
filter
{
it
.
isBusy
!=
1
&&
it
.
is_top
==
0
&&
(
it
.
orderCount
+
it
.
listenOrderCount
>
0
)
}
.
sortedWith
(
mCompare
))
}
}
}
// 重置消息未读数
MsgReceiveHelper
.
reQueryUnreadNumber
{
showData
.
forEachIndexed
{
index
,
_
->
showData
[
index
].
unReadNum
=
MsgReceiveHelper
.
getUnNum
(
showData
[
index
].
toUid
.
toString
())
showData
[
index
].
unReadNum
=
MsgReceiveHelper
.
getUnNum
(
showData
[
index
].
toUid
.
toString
())
}
chatAdapter
?.
notifyDataSetChanged
()
resetPageShow
()
...
...
@@ -205,26 +218,27 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
private
fun
initListData
()
{
chatAdapter
=
ChatAdapter
(
mContext
,
showData
,
this
)
chatAdapter
=
ChatAdapter
(
mContext
,
showData
,
this
)
chatAdapter
?.
setlistener
(
object
:
ChatAdapter
.
ChatRecyclerViewCallback
{
override
fun
onRefresh
()
{
getChatMessageData
()
}
})
chat_recyclerview
.
layoutManager
=
LinearLayoutManager
(
context
)
chat_recyclerview
.
layoutManager
=
LinearLayoutManager
(
context
)
chat_recyclerview
.
adapter
=
chatAdapter
chat_recyclerview
.
setLoadingListener
(
this
)
chat_recyclerview
.
setFootView
(
ChatFooterItemView
(
mContext
),
object
:
CustomFooterViewCallBack
{
override
fun
onSetNoMore
(
p0
:
View
?,
p1
:
Boolean
)
{
}
chat_recyclerview
.
setFootView
(
ChatFooterItemView
(
mContext
),
object
:
CustomFooterViewCallBack
{
override
fun
onSetNoMore
(
p0
:
View
?,
p1
:
Boolean
)
{
}
override
fun
onLoadingMore
(
p0
:
View
?)
{
}
override
fun
onLoadingMore
(
p0
:
View
?)
{
}
override
fun
onLoadMoreComplete
(
p0
:
View
?)
{
}
})
override
fun
onLoadMoreComplete
(
p0
:
View
?)
{
}
})
}
override
fun
onResume
()
{
...
...
@@ -272,7 +286,9 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
}
ll_chat_unusual_view
.
setListener
(
object
:
ChatUnusualView
.
ChatUnusualListener
{
override
fun
onButtonClick
()
{
startActivity
(
ImIn
.
getConsultService
().
expertSearchIntent
(
activity
!!
,
0
,
0
,
false
))
startActivity
(
ImIn
.
getConsultService
().
expertSearchIntent
(
activity
!!
,
0
,
0
,
false
)
)
}
})
}
...
...
@@ -283,7 +299,7 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
ll_chat_unusual_view
.
setUnusualType
(
ChatUnusualView
.
TYPE_UNLOGIN
)
ll_chat_unusual_view
.
setListener
(
object
:
ChatUnusualView
.
ChatUnusualListener
{
override
fun
onButtonClick
()
{
ImIn
.
loginByOneKeyLogin
(
mContext
,
true
)
ImIn
.
loginByOneKeyLogin
(
mContext
,
true
)
}
})
}
...
...
@@ -304,15 +320,19 @@ class ChatFragment : BaseFragment(), XRecyclerView.LoadingListener {
chat_servicing_message
.
setTextColor
(
Color
.
parseColor
(
"#666666"
))
chat_serviced_message
.
setTextColor
(
Color
.
parseColor
(
"#666666"
))
if
(
modelType
==
ChatModelType
.
ALL
)
{
chat_all_message
.
setTextColor
(
resources
.
getColor
(
R
.
color
.
platform_but_text_color_selected
))
chat_all_message
.
setBackgroundResource
(
R
.
drawable
.
im_chat_model_selected_bg
)
}
else
if
(
modelType
==
ChatModelType
.
SERVICING
)
{
chat_servicing_message
.
setTextColor
(
resources
.
getColor
(
R
.
color
.
platform_but_text_color_selected
))
chat_servicing_message
.
setBackgroundResource
(
R
.
drawable
.
im_chat_model_selected_bg
)
}
else
if
(
modelType
==
ChatModelType
.
SERVICED
)
{
chat_serviced_message
.
setTextColor
(
resources
.
getColor
(
R
.
color
.
platform_but_text_color_selected
))
chat_serviced_message
.
setBackgroundResource
(
R
.
drawable
.
im_chat_model_selected_bg
)
when
(
modelType
)
{
ChatModelType
.
ALL
->
{
chat_all_message
.
setTextColor
(
resources
.
getColor
(
R
.
color
.
platform_but_text_color_selected
))
chat_all_message
.
setBackgroundResource
(
R
.
drawable
.
im_chat_model_selected_bg
)
}
ChatModelType
.
SERVICING
->
{
chat_servicing_message
.
setTextColor
(
resources
.
getColor
(
R
.
color
.
platform_but_text_color_selected
))
chat_servicing_message
.
setBackgroundResource
(
R
.
drawable
.
im_chat_model_selected_bg
)
}
ChatModelType
.
SERVICED
->
{
chat_serviced_message
.
setTextColor
(
resources
.
getColor
(
R
.
color
.
platform_but_text_color_selected
))
chat_serviced_message
.
setBackgroundResource
(
R
.
drawable
.
im_chat_model_selected_bg
)
}
}
}
}
\ No newline at end of file
m-im/src/main/java/com/yidianling/im/ui/page/fragment/NoticeFragment.kt
View file @
44c7b91a
...
...
@@ -87,7 +87,6 @@ class NoticeFragment : BaseFragment(), XRecyclerView.LoadingListener {
override
fun
setUserVisibleHint
(
isVisibleToUser
:
Boolean
)
{
super
.
setUserVisibleHint
(
isVisibleToUser
)
if
(
isVisibleToUser
&&
getIsViewCreated
())
{
// 每次展示的时候都需要处理页面展示逻辑
resetPageShow
()
...
...
@@ -104,7 +103,6 @@ class NoticeFragment : BaseFragment(), XRecyclerView.LoadingListener {
* 页面展示状态逻辑
*/
private
fun
resetPageShow
()
{
if
(
ImIn
.
isLogin
())
{
//登录状态
if
(
noticeList
.
size
!=
0
)
{
...
...
m-im/src/main/java/com/yidianling/im/ui/page/fragment/adapter/NoticeAdapter.kt
View file @
44c7b91a
...
...
@@ -20,7 +20,8 @@ class NoticeAdapter(var context: Context, private var mList: ArrayList<NoticeIte
companion
object
{
const
val
TYPE_NORMAL_ITEM
=
1001
// 正常item
// 正常item
const
val
TYPE_NORMAL_ITEM
=
1001
}
override
fun
getItemViewType
(
position
:
Int
):
Int
{
...
...
m-im/src/main/java/com/yidianling/im/ui/page/fragment/bean/NoticeItemBean.kt
View file @
44c7b91a
...
...
@@ -12,6 +12,8 @@ class NoticeItemBean(
var
time
:
String
=
""
,
var
link
:
String
=
""
,
var
timestamp
:
String
=
""
,
var
mType
:
Int
=
0
,
//用于预约提醒传的mType
var
relationId1
:
String
=
""
//用于投诉反馈
//用于预约提醒传的mType
var
mType
:
Int
=
0
,
//用于投诉反馈
var
relationId1
:
String
=
""
)
\ No newline at end of file
m-im/src/main/java/com/yidianling/im/ui/page/fragment/view/NoticeItemView.kt
View file @
44c7b91a
...
...
@@ -31,6 +31,7 @@ class NoticeItemView(mContext: Context): LinearLayout(mContext) {
notice_message_content
.
text
=
bean
.
content
if
(
bean
.
num
>
0
)
{
//未读数
notice_message_unread_num
.
text
=
"${bean.num}"
notice_message_unread_num
.
visibility
=
View
.
VISIBLE
}
else
{
...
...
m-im/src/main/java/com/yidianling/uikit/business/session/viewholder/MsgViewHolderBase.java
View file @
44c7b91a
...
...
@@ -458,4 +458,5 @@ public abstract class MsgViewHolderBase extends RecyclerViewHolder<BaseMultiItem
audioRightSmallTip
.
setVisibility
(
View
.
GONE
);
audioLeftSmallTip
.
setVisibility
(
View
.
GONE
);
}
}
m-im/src/main/java/com/yidianling/uikit/custom/http/ServiceApi.kt
View file @
44c7b91a
...
...
@@ -70,7 +70,7 @@ interface ServiceApi {
fun
focus
(
@Query
(
"doctorId"
)
doctorId
:
String
,
@Query
(
"status"
)
status
:
String
):
Observable
<
BaseAPIResponse
<
Any
>>
//服务列表
@GET
(
"consult/expert-page/products"
)
@GET
(
"consult/expert-page/
n
products"
)
@Headers
(
YDL_DOMAIN
+
YDL_DOMAIN_JAVA
)
fun
serviceList
(
@Query
(
"doctorId"
)
doctorId
:
String
):
Observable
<
BaseAPIResponse
<
List
<
ServiceItemBean
>>>
...
...
m-im/src/main/res/drawable/bg_radius_gray_linear_12.xml
0 → 100644
View file @
44c7b91a
<?xml version="1.0" encoding="utf-8"?>
<shape
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<corners
android:radius=
"12dp"
></corners>
<solid
android:color=
"#999999"
/>
<gradient
android:startColor=
"#999999"
android:endColor=
"#999999"
android:angle=
"180"
/>
</shape>
\ No newline at end of file
m-im/src/main/res/drawable/bg_radius_green_linear_12.xml
0 → 100644
View file @
44c7b91a
<?xml version="1.0" encoding="utf-8"?>
<shape
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<corners
android:radius=
"12dp"
></corners>
<gradient
android:angle=
"180"
android:endColor=
"#23B2FA"
android:startColor=
"#1DA1F2"
/>
</shape>
\ No newline at end of file
m-im/src/main/res/layout/im_ui_message_custom_confirm_order.xml
View file @
44c7b91a
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android=
"http://schemas.android.com/apk/res/android"
xmlns:
app=
"http://schemas.android.com/apk/res-auto
"
xmlns:
tools=
"http://schemas.android.com/tools
"
android:id=
"@+id/lin_root"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
xmlns:tools=
"http://schemas.android.com/tools
"
android:background=
"@drawable/im_bg_radius_no_topleft_white_8
"
android:paddingLeft=
"12dp"
android:paddingRight=
"12dp"
android:paddingTop=
"8dp"
android:padding
Bottom
=
"12dp"
android:
background=
"@drawable/im_bg_radius_no_topleft_white_8
"
>
android:padding
Right
=
"12dp"
android:
paddingBottom=
"12dp
"
>
<ImageView
android:id=
"@+id/img_icon"
android:layout_width=
"14dp"
android:layout_height=
"14dp"
android:layout_marginRight=
"4dp"
android:layout_alignTop=
"@+id/tv_title"
android:layout_alignBottom=
"@+id/tv_title"
android:layout_marginRight=
"4dp"
android:src=
"@mipmap/im_consult_data_sure"
android:visibility=
"gone"
tools:visibility=
"
gone"
/>
tools:visibility=
"
visible"
/>
<TextView
android:id=
"@+id/tv_title"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:textSize=
"14dp"
android:textColor=
"@color/im_color_242424"
android:layout_toRightOf=
"@+id/img_icon"
tools:text=
"我已完成本次咨询,请确认"
/>
android:textColor=
"@color/im_color_242424"
android:textSize=
"14dp"
tools:text=
"我已完成本次咨询,请确认"
/>
<RelativeLayout
android:id=
"@+id/rl_center"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:paddingLeft=
"12dp"
android:paddingRight=
"12dp"
android:paddingTop=
"8dp"
android:paddingBottom=
"8dp"
android:layout_below=
"@+id/tv_title"
android:layout_marginTop=
"8dp"
android:background=
"@drawable/im_bg_radius_f7_2"
>
android:background=
"@drawable/im_bg_radius_f7_2"
android:paddingLeft=
"12dp"
android:paddingTop=
"8dp"
android:paddingRight=
"12dp"
android:paddingBottom=
"8dp"
>
<TextView
android:id=
"@+id/tv_package"
android:layout_width=
"24dp"
android:layout_height=
"14dp"
android:text=
"套餐"
android:layout_marginTop=
"3dp"
android:textSize=
"10dp"
android:textColor=
"@color/platform_color_FFFFFF"
android:gravity=
"center"
android:layout_marginRight=
"3dp"
android:visibility=
"gone"
android:background=
"@drawable/im_bg_radius_yellow_1"
/>
android:background=
"@drawable/im_bg_radius_yellow_1"
android:gravity=
"center"
android:text=
"套餐"
android:textColor=
"@color/platform_color_FFFFFF"
android:textSize=
"10dp"
android:visibility=
"gone"
/>
<TextView
android:id=
"@+id/tv_date"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_below=
"@+id/tv_package"
android:layout_marginTop=
"2dp"
android:textColor=
"@color/platform_color_999999"
android:textSize=
"10dp"
android:layout_marginTop=
"2dp"
android:layout_below=
"@+id/tv_package"
tools:text=
"咨询时间:2019-12-55 12:00:00"
/>
tools:text=
"咨询时间:2019-12-55 12:00:00"
/>
<TextView
android:id=
"@+id/tv_type"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_below=
"@+id/tv_date"
android:layout_marginTop=
"2dp"
android:textColor=
"@color/platform_color_999999"
android:textSize=
"10dp"
android:layout_marginTop=
"2dp"
android:layout_below=
"@+id/tv_date"
tools:text=
"服务方式:电话"
/>
tools:text=
"服务方式:电话"
/>
</RelativeLayout>
<TextView
android:id=
"@+id/tv_submit"
android:layout_width=
"60dp"
android:layout_height=
"24dp"
android:layout_below=
"@+id/rl_center"
android:layout_alignRight=
"@id/rl_center"
android:layout_marginTop=
"12dp"
android:background=
"@drawable/bg_radius_green_linear_12"
android:gravity=
"center"
android:text=
"确认"
android:visibility=
"gone"
android:textColor=
"@color/white"
android:textSize=
"13dp"
/>
</RelativeLayout>
m-im/src/main/res/layout/im_ui_message_custom_order_alreadydone.xml
View file @
44c7b91a
...
...
@@ -32,6 +32,7 @@
tools:text=
"我已完成本次咨询,请确认"
/>
<RelativeLayout
android:id=
"@+id/rl_center"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:paddingLeft=
"12dp"
...
...
@@ -74,5 +75,19 @@
android:layout_below=
"@+id/tv_date"
tools:text=
"服务方式:电话"
/>
</RelativeLayout>
<TextView
android:id=
"@+id/tv_submit"
android:layout_width=
"60dp"
android:layout_height=
"24dp"
android:layout_below=
"@+id/rl_center"
android:layout_alignRight=
"@id/rl_center"
android:layout_marginTop=
"12dp"
android:background=
"@drawable/bg_radius_green_linear_12"
android:gravity=
"center"
android:text=
"确认"
android:visibility=
"gone"
android:textColor=
"@color/white"
android:textSize=
"13dp"
/>
</RelativeLayout>
ydl-platform/src/main/java/com/ydl/ydlcommon/base/config/HttpConfig.kt
View file @
44c7b91a
...
...
@@ -212,7 +212,10 @@ class HttpConfig {
val
message
=
originalResponse
.
message
()
val
api
=
request
.
url
().
encodedPath
()
ActionCountUtils
.
baiDuCount
(
"ydl_user_error_business"
,
"error_log"
,
api
,
params
,
message
)
AliYunRichLogsHelper
.
getInstance
().
sendRichLog
(
AliYunLogConfig
.
API
,
"error_log---api:$api---params:$params ---- message:$message"
)
//阿里云忽略埋点接口
if
(!
api
.
contains
(
"maidian/writeMaiDianData"
)){
AliYunRichLogsHelper
.
getInstance
().
sendRichLog
(
AliYunLogConfig
.
API
,
"error_log---api:$api---params:$params ---- message:$message"
)
}
}
}
originalResponse
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment