V2.3.5
This commit is contained in:
@@ -13,6 +13,7 @@ export 'src/enum/sdk_error_code.dart';
|
||||
export 'src/listener/advanced_msg_listener.dart';
|
||||
export 'src/listener/connect_listener.dart';
|
||||
export 'src/listener/conversation_listener.dart';
|
||||
export 'src/listener/custom_business_listener.dart';
|
||||
export 'src/listener/friendship_listener.dart';
|
||||
export 'src/listener/group_listener.dart';
|
||||
export 'src/listener/msg_send_progress_listener.dart';
|
||||
|
||||
@@ -11,4 +11,5 @@ class ListenerType {
|
||||
static final msgSendProgressListener = "msgSendProgressListener";
|
||||
static final workMomentsListener = "workMomentsListener";
|
||||
static final organizationListener = "organizationListener";
|
||||
static final customBusinessListener = "customBusinessListener";
|
||||
}
|
||||
|
||||
9
lib/src/listener/custom_business_listener.dart
Normal file
9
lib/src/listener/custom_business_listener.dart
Normal file
@@ -0,0 +1,9 @@
|
||||
class OnCustomBusinessListener {
|
||||
Function(String s)? onRecvCustomBusinessMessage;
|
||||
|
||||
OnCustomBusinessListener({this.onRecvCustomBusinessMessage});
|
||||
|
||||
void recvCustomBusinessMessage(String s) {
|
||||
onRecvCustomBusinessMessage?.call(s);
|
||||
}
|
||||
}
|
||||
@@ -313,6 +313,15 @@ class IMManager {
|
||||
organizationManager.listener.organizationUpdated();
|
||||
break;
|
||||
}
|
||||
} else if (call.method == ListenerType.customBusinessListener) {
|
||||
String type = call.arguments['type'];
|
||||
String data = call.arguments['data'];
|
||||
switch (type) {
|
||||
case 'onRecvCustomBusinessMessage':
|
||||
messageManager.customBusinessListener?.onRecvCustomBusinessMessage
|
||||
?.call(data);
|
||||
break;
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
print(
|
||||
@@ -329,6 +338,8 @@ class IMManager {
|
||||
/// [dataDir] SDK数据库存储目录
|
||||
/// [objectStorage] 存储对象 cos/minio
|
||||
/// [logLevel] 日志 1不打印
|
||||
/// [enabledEncryption] true:加密
|
||||
/// [enabledCompression] true:压缩
|
||||
Future<dynamic> initSDK({
|
||||
required int platform,
|
||||
required String apiAddr,
|
||||
@@ -339,6 +350,7 @@ class IMManager {
|
||||
String objectStorage = 'cos',
|
||||
String? encryptionKey,
|
||||
bool enabledEncryption = false,
|
||||
bool enabledCompression = false,
|
||||
String? operationID,
|
||||
}) {
|
||||
this._connectListener = listener;
|
||||
@@ -355,6 +367,7 @@ class IMManager {
|
||||
"object_storage": objectStorage,
|
||||
"encryption_key": encryptionKey,
|
||||
"is_need_encryption": enabledEncryption,
|
||||
"is_compression ": enabledCompression,
|
||||
"operationID": Utils.checkOperationID(operationID),
|
||||
},
|
||||
));
|
||||
|
||||
@@ -7,6 +7,7 @@ class MessageManager {
|
||||
// List<AdvancedMsgListener> advancedMsgListeners = List.empty(growable: true);
|
||||
OnMsgSendProgressListener? msgSendProgressListener;
|
||||
late OnAdvancedMsgListener msgListener;
|
||||
OnCustomBusinessListener? customBusinessListener;
|
||||
|
||||
MessageManager(this._channel);
|
||||
|
||||
@@ -874,6 +875,12 @@ class MessageManager {
|
||||
}))
|
||||
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
|
||||
|
||||
/// 用户资料改变监听
|
||||
Future setCustomBusinessListener(OnCustomBusinessListener listener) {
|
||||
this.customBusinessListener = listener;
|
||||
return _channel.invokeMethod('setCustomBusinessListener', _buildParam({}));
|
||||
}
|
||||
|
||||
static Map _buildParam(Map param) {
|
||||
param["ManagerName"] = "messageManager";
|
||||
return param;
|
||||
|
||||
Reference in New Issue
Block a user