|
|
@ -89,8 +89,10 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
|
|
|
|
|
|
|
|
socketClient.addCallback(_toUser.mid, (Message message) { |
|
|
|
socketClient.addCallback(_toUser.mid, (Message message) { |
|
|
|
messages.insert(0, message); |
|
|
|
messages.insert(0, message); |
|
|
|
refreshState(); |
|
|
|
messageShowTime().then((value) { |
|
|
|
jumpToBottom(); |
|
|
|
refreshState(); |
|
|
|
|
|
|
|
jumpToBottom(); |
|
|
|
|
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
refreshState(); |
|
|
|
refreshState(); |
|
|
|
jumpToBottom(); |
|
|
|
jumpToBottom(); |
|
|
@ -105,6 +107,7 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
messages.addAll(messagePage); |
|
|
|
messages.addAll(messagePage); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
await messageShowTime(); |
|
|
|
if (messagePage.isEmpty) { |
|
|
|
if (messagePage.isEmpty) { |
|
|
|
refreshController.loadNoData(); |
|
|
|
refreshController.loadNoData(); |
|
|
|
return; |
|
|
|
return; |
|
|
@ -114,6 +117,14 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
return Future.value(); |
|
|
|
return Future.value(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Future messageShowTime() async { |
|
|
|
|
|
|
|
List<Message> messagePages = await hxDatabase.queryTList(_toUser.mid); |
|
|
|
|
|
|
|
for (var value in messages) { |
|
|
|
|
|
|
|
Message message = messagePages.firstWhere((element) => value.id == element.id, orElse: () => null); |
|
|
|
|
|
|
|
value.showTime = message != null; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
///查询个人信息 |
|
|
|
///查询个人信息 |
|
|
|
queryUser() async { |
|
|
|
queryUser() async { |
|
|
|
final SharedPreferences value = await SharedPreferences.getInstance(); |
|
|
|
final SharedPreferences value = await SharedPreferences.getInstance(); |
|
|
@ -123,10 +134,8 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
userInfo = UserInfo.fromJson(jsonDecode(value.getString('user'))); |
|
|
|
userInfo = UserInfo.fromJson(jsonDecode(value.getString('user'))); |
|
|
|
} |
|
|
|
} |
|
|
|
if (apiService == null) |
|
|
|
if (apiService == null) |
|
|
|
apiService = |
|
|
|
apiService = ApiService(Dio(), context: context, token: value.getString("token")); |
|
|
|
ApiService(Dio(), context: context, token: value.getString("token")); |
|
|
|
BaseData<UserInfo> baseData = await apiService.queryInfo().catchError((onError) {}); |
|
|
|
BaseData<UserInfo> baseData = |
|
|
|
|
|
|
|
await apiService.queryInfo().catchError((onError) {}); |
|
|
|
|
|
|
|
if (baseData != null && baseData.isSuccess) { |
|
|
|
if (baseData != null && baseData.isSuccess) { |
|
|
|
setState(() { |
|
|
|
setState(() { |
|
|
|
userInfo = baseData.data; |
|
|
|
userInfo = baseData.data; |
|
|
@ -374,7 +383,8 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
child: SingleChildScrollView( |
|
|
|
child: SingleChildScrollView( |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
controller: scrollController, |
|
|
|
controller: scrollController, |
|
|
|
child: chatDetailsList()), |
|
|
|
child: chatDetailsList(), |
|
|
|
|
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
flex: 1, |
|
|
|
flex: 1, |
|
|
|
), |
|
|
|
), |
|
|
@ -382,7 +392,8 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
], |
|
|
|
], |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
)); |
|
|
|
), |
|
|
|
|
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
///聊天列表 |
|
|
|
///聊天列表 |
|
|
@ -419,24 +430,25 @@ class _ChatDetailsPage extends State<ChatDetailsPage> |
|
|
|
), |
|
|
|
), |
|
|
|
child: Column( |
|
|
|
child: Column( |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Text( |
|
|
|
if (messages[position].showTime) |
|
|
|
// position == messages.length-1 |
|
|
|
Text( |
|
|
|
// ? |
|
|
|
// position == messages.length-1 |
|
|
|
AppUtils.milliTimeFormatter(DateTime.fromMillisecondsSinceEpoch( |
|
|
|
// ? |
|
|
|
int.parse(messages[position].time))) |
|
|
|
AppUtils.milliTimeFormatter(DateTime.fromMillisecondsSinceEpoch( |
|
|
|
// : AppUtils.getTimeDisplay( |
|
|
|
int.parse(messages[position].time))) |
|
|
|
// DateTime.fromMillisecondsSinceEpoch( |
|
|
|
// : AppUtils.getTimeDisplay( |
|
|
|
// int.parse(messages[position].time)), |
|
|
|
// DateTime.fromMillisecondsSinceEpoch( |
|
|
|
// DateTime.fromMillisecondsSinceEpoch( |
|
|
|
// int.parse(messages[position].time)), |
|
|
|
// int.parse(messages[position+1].time))) |
|
|
|
// DateTime.fromMillisecondsSinceEpoch( |
|
|
|
, |
|
|
|
// int.parse(messages[position+1].time))) |
|
|
|
textAlign: TextAlign.center, |
|
|
|
, |
|
|
|
style: TextStyle( |
|
|
|
textAlign: TextAlign.center, |
|
|
|
color: Color(0xFFA29E9E), |
|
|
|
style: TextStyle( |
|
|
|
fontSize: 10.sp, |
|
|
|
color: Color(0xFFA29E9E), |
|
|
|
fontWeight: MyFontWeight.regular, |
|
|
|
fontSize: 10.sp, |
|
|
|
|
|
|
|
fontWeight: MyFontWeight.regular, |
|
|
|
|
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
|
|
|
|
// if (messages.indexOf(message) == (messages.length - 1)) |
|
|
|
// if (messages.indexOf(message) == (messages.length - 1)) |
|
|
|
// Padding( |
|
|
|
// Padding( |
|
|
|
// padding: EdgeInsets.only(top: 10.h, bottom: 24.h), |
|
|
|
// padding: EdgeInsets.only(top: 10.h, bottom: 24.h), |
|
|
|