mirror of
https://gitlab.com/comunic/comunicmobile
synced 2024-11-22 12:59:21 +00:00
Get call status from server
This commit is contained in:
parent
5eaf8d6b72
commit
f227209e9b
@ -208,14 +208,19 @@ class ConversationsHelper {
|
|||||||
/// Turn an API entry into a [Conversation] object
|
/// Turn an API entry into a [Conversation] object
|
||||||
Conversation _apiToConversation(Map<String, dynamic> map) {
|
Conversation _apiToConversation(Map<String, dynamic> map) {
|
||||||
return Conversation(
|
return Conversation(
|
||||||
id: map["ID"],
|
id: map["ID"],
|
||||||
ownerID: map["ID_owner"],
|
ownerID: map["ID_owner"],
|
||||||
lastActive: map["last_active"],
|
lastActive: map["last_active"],
|
||||||
name: map["name"] == false ? null : map["name"],
|
name: map["name"] == false ? null : map["name"],
|
||||||
following: map["following"] == 1,
|
following: map["following"] == 1,
|
||||||
sawLastMessage: map["saw_last_message"] == 1,
|
sawLastMessage: map["saw_last_message"] == 1,
|
||||||
members: List<int>.from(map["members"]),
|
members: List<int>.from(map["members"]),
|
||||||
);
|
callCapabilities: map["can_have_video_call"]
|
||||||
|
? CallCapabilities.VIDEO
|
||||||
|
: (map["can_have_call"]
|
||||||
|
? CallCapabilities.AUDIO
|
||||||
|
: CallCapabilities.NONE),
|
||||||
|
isHavingCall: map["has_call_now"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Parse a list of messages given by the server
|
/// Parse a list of messages given by the server
|
||||||
|
@ -8,6 +8,8 @@ import 'package:meta/meta.dart';
|
|||||||
///
|
///
|
||||||
/// @author Pierre HUBERT
|
/// @author Pierre HUBERT
|
||||||
|
|
||||||
|
enum CallCapabilities { NONE, AUDIO, VIDEO }
|
||||||
|
|
||||||
class Conversation extends CacheModel implements Comparable {
|
class Conversation extends CacheModel implements Comparable {
|
||||||
final int ownerID;
|
final int ownerID;
|
||||||
final int lastActive;
|
final int lastActive;
|
||||||
@ -15,6 +17,8 @@ class Conversation extends CacheModel implements Comparable {
|
|||||||
final bool following;
|
final bool following;
|
||||||
final bool sawLastMessage;
|
final bool sawLastMessage;
|
||||||
final List<int> members;
|
final List<int> members;
|
||||||
|
final CallCapabilities callCapabilities;
|
||||||
|
final bool isHavingCall;
|
||||||
|
|
||||||
const Conversation({
|
const Conversation({
|
||||||
@required int id,
|
@required int id,
|
||||||
@ -24,12 +28,16 @@ class Conversation extends CacheModel implements Comparable {
|
|||||||
@required this.following,
|
@required this.following,
|
||||||
@required this.sawLastMessage,
|
@required this.sawLastMessage,
|
||||||
@required this.members,
|
@required this.members,
|
||||||
|
this.callCapabilities = CallCapabilities.NONE,
|
||||||
|
this.isHavingCall = false,
|
||||||
}) : assert(id != null),
|
}) : assert(id != null),
|
||||||
assert(ownerID != null),
|
assert(ownerID != null),
|
||||||
assert(lastActive != null),
|
assert(lastActive != null),
|
||||||
assert(following != null),
|
assert(following != null),
|
||||||
assert(sawLastMessage != null),
|
assert(sawLastMessage != null),
|
||||||
assert(members != null),
|
assert(members != null),
|
||||||
|
assert(callCapabilities != null),
|
||||||
|
assert(isHavingCall != null),
|
||||||
super(id: id);
|
super(id: id);
|
||||||
|
|
||||||
/// Check out whether a conversation has a fixed name or not
|
/// Check out whether a conversation has a fixed name or not
|
||||||
@ -45,8 +53,12 @@ class Conversation extends CacheModel implements Comparable {
|
|||||||
name = map[ConversationTableContract.C_NAME],
|
name = map[ConversationTableContract.C_NAME],
|
||||||
following = map[ConversationTableContract.C_FOLLOWING] == 1,
|
following = map[ConversationTableContract.C_FOLLOWING] == 1,
|
||||||
sawLastMessage = map[ConversationTableContract.C_SAW_LAST_MESSAGE] == 1,
|
sawLastMessage = map[ConversationTableContract.C_SAW_LAST_MESSAGE] == 1,
|
||||||
members = listToIntList(
|
members =
|
||||||
map[ConversationTableContract.C_MEMBERS].split(",")),
|
listToIntList(map[ConversationTableContract.C_MEMBERS].split(",")),
|
||||||
|
|
||||||
|
// By default, we can not do any call
|
||||||
|
callCapabilities = CallCapabilities.NONE,
|
||||||
|
isHavingCall = false,
|
||||||
super.fromMap(map);
|
super.fromMap(map);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
|
@ -42,7 +42,8 @@ class _ConversationRouteState extends State<ConversationRoute> {
|
|||||||
Future<void> _loadConversation() async {
|
Future<void> _loadConversation() async {
|
||||||
setError(false);
|
setError(false);
|
||||||
|
|
||||||
_conversation = await _conversationsHelper.getSingle(widget.conversationID);
|
_conversation = await _conversationsHelper.getSingle(widget.conversationID,
|
||||||
|
force: true);
|
||||||
|
|
||||||
if (_conversation == null) return setError(true);
|
if (_conversation == null) return setError(true);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user