Compare commits
19 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
bd76c29f15 | ||
|
|
9998f9b99c | ||
|
|
50bf41df51 | ||
|
|
7af14f995c | ||
|
|
3c28242303 | ||
|
|
b443caabc5 | ||
|
|
50dcfcf495 | ||
|
|
e13c4c6658 | ||
|
|
58fa80a2f8 | ||
|
|
f929c73d09 | ||
|
|
1b70214455 | ||
|
|
6573f03e96 | ||
|
|
8852275b1e | ||
|
|
80a8fab891 | ||
|
|
ea82c50d79 | ||
|
|
70423d9756 | ||
|
|
d02be57c1e | ||
|
|
239e111ee4 | ||
|
|
5d88b4e5d1 |
@@ -1,3 +1,7 @@
|
|||||||
|
## 3.8.2
|
||||||
|
|
||||||
|
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.2)
|
||||||
|
|
||||||
## 3.8.1+2
|
## 3.8.1+2
|
||||||
|
|
||||||
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.1)
|
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.1)
|
||||||
|
|||||||
@@ -15,6 +15,10 @@ def getCurrentProjectDir() {
|
|||||||
|
|
||||||
buildscript {
|
buildscript {
|
||||||
repositories {
|
repositories {
|
||||||
|
maven { url 'https://maven.aliyun.com/repository/public' }
|
||||||
|
maven { url 'https://maven.aliyun.com/repository/central' }
|
||||||
|
maven { url 'https://maven.aliyun.com/nexus/content/repositories/google' }
|
||||||
|
maven { url 'https://maven.aliyun.com/repository/gradle-plugin' }
|
||||||
google()
|
google()
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
@@ -38,7 +42,7 @@ rootProject.allprojects {
|
|||||||
apply plugin: 'com.android.library'
|
apply plugin: 'com.android.library'
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 30
|
compileSdkVersion 34
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
@@ -53,5 +57,5 @@ android {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation 'com.openim:sdkcore:1.0.0'
|
implementation 'com.openim:sdkcore:1.0.8'
|
||||||
}
|
}
|
||||||
@@ -29,6 +29,14 @@ public class OnAdvancedMsgListener implements open_im_sdk_callback.OnAdvancedMsg
|
|||||||
CommonUtil.emitEvent("advancedMsgListener", "onNewRecvMessageRevoked", values);
|
CommonUtil.emitEvent("advancedMsgListener", "onNewRecvMessageRevoked", values);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onNewRecvMessageEdited(String s) {
|
||||||
|
final Map<String, String> values = new ArrayMap<>();
|
||||||
|
values.put("id", id);
|
||||||
|
values.put("messageEdited", s);
|
||||||
|
CommonUtil.emitEvent("advancedMsgListener", "onNewRecvMessageEdited", values);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRecvC2CReadReceipt(String s) {
|
public void onRecvC2CReadReceipt(String s) {
|
||||||
final Map<String, String> values = new ArrayMap<>();
|
final Map<String, String> values = new ArrayMap<>();
|
||||||
|
|||||||
@@ -42,6 +42,16 @@ public class MessageManager extends BaseManager {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void editMessage(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.editMessage(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "conversationID"),
|
||||||
|
value(methodCall, "clientMsgID"),
|
||||||
|
jsonValue(methodCall, "message")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public void deleteMessageFromLocalStorage(MethodCall methodCall, MethodChannel.Result result) {
|
public void deleteMessageFromLocalStorage(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.deleteMessageFromLocalStorage(
|
Open_im_sdk.deleteMessageFromLocalStorage(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
@@ -378,6 +388,16 @@ public class MessageManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "fileElem")));
|
jsonValue(methodCall, "fileElem")));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void FetchSurroundingMessages(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
CommonUtil.runMainThreadReturn(result,
|
||||||
|
Open_im_sdk.createFileMessageByURL(
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "message"),
|
||||||
|
int2long(methodCall, "before"),
|
||||||
|
int2long(methodCall, "after")));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public void setCustomBusinessListener(MethodCall methodCall, MethodChannel.Result result) {
|
public void setCustomBusinessListener(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.setCustomBusinessListener(new OnCustomBusinessListener());
|
Open_im_sdk.setCustomBusinessListener(new OnCustomBusinessListener());
|
||||||
|
|
||||||
|
|||||||
@@ -49,7 +49,25 @@ public class CommonUtil {
|
|||||||
res.put("errMsg", errMsg);
|
res.put("errMsg", errMsg);
|
||||||
}
|
}
|
||||||
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " { method:" + method + ", type:" + type + " }");
|
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " { method:" + method + ", type:" + type + " }");
|
||||||
FlutterOpenimSdkPlugin.channel.invokeMethod(method, res);
|
FlutterOpenimSdkPlugin.channel.invokeMethod(method, res, new MethodChannel.Result() {
|
||||||
|
@Override
|
||||||
|
public void success(Object result) {
|
||||||
|
// 处理成功返回值
|
||||||
|
Log.i("F-OpenIMSDK(native call flutter)", "Method " + method + " returned: ");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void error(String errorCode, String errorMessage, Object errorDetails) {
|
||||||
|
// 处理错误
|
||||||
|
Log.e("F-OpenIMSDK(native call flutter)", "Method " + method + " error: " + errorCode + ", " + errorMessage);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void notImplemented() {
|
||||||
|
// 处理未实现的方法
|
||||||
|
Log.w("F-OpenIMSDK(native call flutter)", "Method " + method + " not implemented");
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
self["setAdvancedMsgListener"] = setAdvancedMsgListener
|
self["setAdvancedMsgListener"] = setAdvancedMsgListener
|
||||||
self["sendMessage"] = sendMessage
|
self["sendMessage"] = sendMessage
|
||||||
self["revokeMessage"] = revokeMessage
|
self["revokeMessage"] = revokeMessage
|
||||||
|
self["editMessage"] = editMessage
|
||||||
self["deleteMessageFromLocalStorage"] = deleteMessageFromLocalStorage
|
self["deleteMessageFromLocalStorage"] = deleteMessageFromLocalStorage
|
||||||
self["deleteMessageFromLocalAndSvr"] = deleteMessageFromLocalAndSvr
|
self["deleteMessageFromLocalAndSvr"] = deleteMessageFromLocalAndSvr
|
||||||
self["deleteAllMsgFromLocal"] = deleteAllMsgFromLocal
|
self["deleteAllMsgFromLocal"] = deleteAllMsgFromLocal
|
||||||
@@ -47,6 +48,10 @@ public class MessageManager: BaseServiceManager {
|
|||||||
self["setMessageLocalEx"] = setMessageLocalEx
|
self["setMessageLocalEx"] = setMessageLocalEx
|
||||||
self["setAppBadge"] = setAppBadge
|
self["setAppBadge"] = setAppBadge
|
||||||
|
|
||||||
|
self["fetchSurroundingMessages"] = fetchSurroundingMessages
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
self["sendMessageNotOss"] = sendMessageNotOss
|
self["sendMessageNotOss"] = sendMessageNotOss
|
||||||
self["createImageMessageByURL"] = createImageMessageByURL
|
self["createImageMessageByURL"] = createImageMessageByURL
|
||||||
self["createSoundMessageByURL"] = createSoundMessageByURL
|
self["createSoundMessageByURL"] = createSoundMessageByURL
|
||||||
@@ -72,6 +77,10 @@ public class MessageManager: BaseServiceManager {
|
|||||||
Open_im_sdkRevokeMessage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "conversationID"],methodCall[string: "clientMsgID"])
|
Open_im_sdkRevokeMessage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "conversationID"],methodCall[string: "clientMsgID"])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func editMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
|
Open_im_sdkEditMessage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "conversationID"],methodCall[string: "clientMsgID"],methodCall[jsonString: "message"])
|
||||||
|
}
|
||||||
|
|
||||||
func deleteMessageFromLocalStorage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func deleteMessageFromLocalStorage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkDeleteMessageFromLocalStorage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "conversationID"],methodCall[string: "clientMsgID"])
|
Open_im_sdkDeleteMessageFromLocalStorage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "conversationID"],methodCall[string: "clientMsgID"])
|
||||||
}
|
}
|
||||||
@@ -250,6 +259,13 @@ public class MessageManager: BaseServiceManager {
|
|||||||
Open_im_sdkSetCustomBusinessListener(CustomBusinessListener(channel: channel))
|
Open_im_sdkSetCustomBusinessListener(CustomBusinessListener(channel: channel))
|
||||||
callBack(result)
|
callBack(result)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func fetchSurroundingMessages(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
|
Open_im_sdkFetchSurroundingMessages(BaseCallback(result: result),methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[int: "before"], methodCall[int: "after"])
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SendMsgProgressListener: NSObject, Open_im_sdk_callbackSendMsgCallBackProtocol {
|
public class SendMsgProgressListener: NSObject, Open_im_sdk_callbackSendMsgCallBackProtocol {
|
||||||
@@ -304,6 +320,13 @@ public class AdvancedMsgListener: NSObject, Open_im_sdk_callbackOnAdvancedMsgLis
|
|||||||
CommonUtil.emitEvent(channel: channel, method: "advancedMsgListener", type: "onNewRecvMessageRevoked", errCode: nil, errMsg: nil, data: values)
|
CommonUtil.emitEvent(channel: channel, method: "advancedMsgListener", type: "onNewRecvMessageRevoked", errCode: nil, errMsg: nil, data: values)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public func onNewRecvMessageEdited(_ messageEdited: String?) {
|
||||||
|
var values: [String: Any] = [:]
|
||||||
|
values["id"] = id
|
||||||
|
values["messageEdited"] = messageEdited
|
||||||
|
CommonUtil.emitEvent(channel: channel, method: "advancedMsgListener", type: "onNewRecvMessageEdited", errCode: nil, errMsg: nil, data: values)
|
||||||
|
}
|
||||||
|
|
||||||
public func onRecvC2CReadReceipt(_ msgReceiptList: String?) {
|
public func onRecvC2CReadReceipt(_ msgReceiptList: String?) {
|
||||||
var values: [String: Any] = [:]
|
var values: [String: Any] = [:]
|
||||||
values["id"] = id
|
values["id"] = id
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
#
|
#
|
||||||
Pod::Spec.new do |s|
|
Pod::Spec.new do |s|
|
||||||
s.name = 'flutter_openim_sdk'
|
s.name = 'flutter_openim_sdk'
|
||||||
s.version = '0.0.1'
|
s.version = '0.0.7'
|
||||||
s.summary = 'A new Flutter project.'
|
s.summary = 'A new Flutter project.'
|
||||||
s.description = <<-DESC
|
s.description = <<-DESC
|
||||||
A new Flutter project.
|
A new Flutter project.
|
||||||
@@ -15,11 +15,11 @@ A new Flutter project.
|
|||||||
s.source = { :path => '.' }
|
s.source = { :path => '.' }
|
||||||
s.source_files = 'Classes/**/*'
|
s.source_files = 'Classes/**/*'
|
||||||
s.dependency 'Flutter'
|
s.dependency 'Flutter'
|
||||||
s.platform = :ios, '11.0'
|
s.platform = :ios, '13.0'
|
||||||
|
|
||||||
#s.ios.vendored_frameworks = 'frameworks/*.xcframework'
|
#s.ios.vendored_frameworks = 'frameworks/*.xcframework'
|
||||||
#s.vendored_frameworks = 'frameworks/*.xcframework'
|
#s.vendored_frameworks = 'frameworks/*.xcframework'
|
||||||
s.dependency 'openim_sdk_core_ios','0.2.0'
|
s.dependency 'openim_sdk_core_ios','0.6.0'
|
||||||
s.static_framework = true
|
s.static_framework = true
|
||||||
s.library = 'resolv'
|
s.library = 'resolv'
|
||||||
|
|
||||||
|
|||||||
@@ -168,6 +168,9 @@ class MessageType {
|
|||||||
/// Recall Message
|
/// Recall Message
|
||||||
static const revokeMessageNotification = 2101;
|
static const revokeMessageNotification = 2101;
|
||||||
|
|
||||||
|
/// Edit Message
|
||||||
|
static const editMessageNotification = 2108;
|
||||||
|
|
||||||
/// Single Chat Has Read Receipt
|
/// Single Chat Has Read Receipt
|
||||||
static const signalHasReadReceiptNotification = 2150;
|
static const signalHasReadReceiptNotification = 2150;
|
||||||
|
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
|||||||
class OnAdvancedMsgListener {
|
class OnAdvancedMsgListener {
|
||||||
Function(Message msg)? onMsgDeleted;
|
Function(Message msg)? onMsgDeleted;
|
||||||
Function(RevokedInfo info)? onNewRecvMessageRevoked;
|
Function(RevokedInfo info)? onNewRecvMessageRevoked;
|
||||||
|
Function(EditedInfo info)? onNewRecvMessageEdited;
|
||||||
Function(List<ReadReceiptInfo> list)? onRecvC2CReadReceipt;
|
Function(List<ReadReceiptInfo> list)? onRecvC2CReadReceipt;
|
||||||
Function(Message msg)? onRecvNewMessage;
|
Function(Message msg)? onRecvNewMessage;
|
||||||
Function(Message msg)? onRecvOfflineNewMessage;
|
Function(Message msg)? onRecvOfflineNewMessage;
|
||||||
@@ -15,6 +16,7 @@ class OnAdvancedMsgListener {
|
|||||||
OnAdvancedMsgListener({
|
OnAdvancedMsgListener({
|
||||||
this.onMsgDeleted,
|
this.onMsgDeleted,
|
||||||
this.onNewRecvMessageRevoked,
|
this.onNewRecvMessageRevoked,
|
||||||
|
this.onNewRecvMessageEdited,
|
||||||
this.onRecvC2CReadReceipt,
|
this.onRecvC2CReadReceipt,
|
||||||
this.onRecvNewMessage,
|
this.onRecvNewMessage,
|
||||||
this.onRecvOfflineNewMessage,
|
this.onRecvOfflineNewMessage,
|
||||||
@@ -30,6 +32,12 @@ class OnAdvancedMsgListener {
|
|||||||
onNewRecvMessageRevoked?.call(info);
|
onNewRecvMessageRevoked?.call(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Message has been edited
|
||||||
|
void newRecvMessageEdited(EditedInfo info) {
|
||||||
|
onNewRecvMessageEdited?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/// C2C Message Read Receipt
|
/// C2C Message Read Receipt
|
||||||
void recvC2CReadReceipt(List<ReadReceiptInfo> list) {
|
void recvC2CReadReceipt(List<ReadReceiptInfo> list) {
|
||||||
onRecvC2CReadReceipt?.call(list);
|
onRecvC2CReadReceipt?.call(list);
|
||||||
|
|||||||
@@ -179,6 +179,11 @@ class IMManager {
|
|||||||
var info = Utils.toObj(value, (map) => RevokedInfo.fromJson(map));
|
var info = Utils.toObj(value, (map) => RevokedInfo.fromJson(map));
|
||||||
messageManager.msgListener.newRecvMessageRevoked(info);
|
messageManager.msgListener.newRecvMessageRevoked(info);
|
||||||
break;
|
break;
|
||||||
|
case 'onNewRecvMessageEdited':
|
||||||
|
var value = call.arguments['data']['messageEdited'];
|
||||||
|
var info = Utils.toObj(value, (map) => EditedInfo.fromJson(map));
|
||||||
|
messageManager.msgListener.newRecvMessageEdited(info);
|
||||||
|
break;
|
||||||
case 'onRecvC2CReadReceipt':
|
case 'onRecvC2CReadReceipt':
|
||||||
var value = call.arguments['data']['msgReceiptList'];
|
var value = call.arguments['data']['msgReceiptList'];
|
||||||
var list = Utils.toList(value, (map) => ReadReceiptInfo.fromJson(map));
|
var list = Utils.toList(value, (map) => ReadReceiptInfo.fromJson(map));
|
||||||
|
|||||||
@@ -151,7 +151,8 @@ class MessageManager {
|
|||||||
|
|
||||||
/// Typing status update
|
/// Typing status update
|
||||||
/// [msgTip] Custom content
|
/// [msgTip] Custom content
|
||||||
@Deprecated('Use [OpenIM.iMManager.conversationManager.changeInputStates(conversationID:focus:)] instead')
|
@Deprecated(
|
||||||
|
'Use [OpenIM.iMManager.conversationManager.changeInputStates(conversationID:focus:)] instead')
|
||||||
Future typingStatusUpdate({
|
Future typingStatusUpdate({
|
||||||
required String userID,
|
required String userID,
|
||||||
String? msgTip,
|
String? msgTip,
|
||||||
@@ -531,7 +532,8 @@ class MessageManager {
|
|||||||
},
|
},
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) => Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
.then((value) =>
|
||||||
|
Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
||||||
|
|
||||||
/// Revoke a message
|
/// Revoke a message
|
||||||
/// [message] The message to be revoked
|
/// [message] The message to be revoked
|
||||||
@@ -548,6 +550,23 @@ class MessageManager {
|
|||||||
"operationID": Utils.checkOperationID(operationID),
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
/// Edit a message
|
||||||
|
/// [message] The message to be edited
|
||||||
|
Future editMessage({
|
||||||
|
required String conversationID,
|
||||||
|
required String clientMsgID,
|
||||||
|
String? operationID,
|
||||||
|
required Message message,
|
||||||
|
}) =>
|
||||||
|
_channel.invokeMethod(
|
||||||
|
'editMessage',
|
||||||
|
_buildParam({
|
||||||
|
'conversationID': conversationID,
|
||||||
|
'clientMsgID': clientMsgID,
|
||||||
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
|
'message': message.toJson(),
|
||||||
|
}));
|
||||||
|
|
||||||
/// Mark messages as read
|
/// Mark messages as read
|
||||||
/// [conversationID] Conversation ID
|
/// [conversationID] Conversation ID
|
||||||
/// [messageIDList] List of clientMsgIDs of messages to be marked as read
|
/// [messageIDList] List of clientMsgIDs of messages to be marked as read
|
||||||
@@ -587,7 +606,8 @@ class MessageManager {
|
|||||||
'lastMinSeq': lastMinSeq ?? 0,
|
'lastMinSeq': lastMinSeq ?? 0,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
.then((value) =>
|
||||||
|
Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
||||||
|
|
||||||
/// Get chat history (newly received chat history after startMsg). Used for locating a specific message in global search and then fetching messages received after that message.
|
/// Get chat history (newly received chat history after startMsg). Used for locating a specific message in global search and then fetching messages received after that message.
|
||||||
/// [conversationID] Conversation ID, can be used for querying notifications
|
/// [conversationID] Conversation ID, can be used for querying notifications
|
||||||
@@ -610,7 +630,8 @@ class MessageManager {
|
|||||||
'lastMinSeq': lastMinSeq ?? 0,
|
'lastMinSeq': lastMinSeq ?? 0,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
.then((value) =>
|
||||||
|
Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
||||||
|
|
||||||
/// Find message details
|
/// Find message details
|
||||||
/// [conversationID] Conversation ID
|
/// [conversationID] Conversation ID
|
||||||
@@ -626,7 +647,8 @@ class MessageManager {
|
|||||||
'searchParams': searchParams.map((e) => e.toJson()).toList(),
|
'searchParams': searchParams.map((e) => e.toJson()).toList(),
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) => Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
.then((value) =>
|
||||||
|
Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
||||||
|
|
||||||
/// Rich text message
|
/// Rich text message
|
||||||
/// [text] Input content
|
/// [text] Input content
|
||||||
@@ -794,6 +816,28 @@ class MessageManager {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Fetch Surrounding Messages
|
||||||
|
/// [message] Message content
|
||||||
|
/// [before] message index - before
|
||||||
|
/// [after] message index - after
|
||||||
|
/// [operationID] Operation ID
|
||||||
|
Future<List<Message>> FetchSurroundingMessages({
|
||||||
|
required Message message,
|
||||||
|
int? before,
|
||||||
|
int? after,
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel
|
||||||
|
.invokeMethod(
|
||||||
|
'fetchSurroundingMessages',
|
||||||
|
_buildParam({
|
||||||
|
'message': message.toJson(),
|
||||||
|
'before': before ?? 0,
|
||||||
|
'after': after ?? 0,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) => Utils.toList(value, (map) => Message.fromJson(map)));
|
||||||
|
|
||||||
static Map _buildParam(Map<String, dynamic> param) {
|
static Map _buildParam(Map<String, dynamic> param) {
|
||||||
param["ManagerName"] = "messageManager";
|
param["ManagerName"] = "messageManager";
|
||||||
param = Utils.cleanMap(param);
|
param = Utils.cleanMap(param);
|
||||||
|
|||||||
@@ -1123,6 +1123,82 @@ class RevokedInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/// Message revocation details
|
||||||
|
class EditedInfo {
|
||||||
|
/// Editer's ID
|
||||||
|
String? editerID;
|
||||||
|
|
||||||
|
|
||||||
|
/// Message ID
|
||||||
|
String? clientMsgID;
|
||||||
|
|
||||||
|
/// Revocation time
|
||||||
|
int? editTime;
|
||||||
|
|
||||||
|
/// Message sending time
|
||||||
|
int? sourceMessageSendTime;
|
||||||
|
|
||||||
|
/// Message sender
|
||||||
|
String? sourceMessageSendID;
|
||||||
|
|
||||||
|
/// Message sender's nickname
|
||||||
|
String? sourceMessageSenderNickname;
|
||||||
|
|
||||||
|
/// Conversation type [ConversationType]
|
||||||
|
int? sessionType;
|
||||||
|
|
||||||
|
/// Message contentType
|
||||||
|
int? contentType;
|
||||||
|
|
||||||
|
/// Message content
|
||||||
|
String? content;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
EditedInfo({
|
||||||
|
this.editerID,
|
||||||
|
this.clientMsgID,
|
||||||
|
this.editTime,
|
||||||
|
this.sourceMessageSendTime,
|
||||||
|
this.sourceMessageSendID,
|
||||||
|
this.sourceMessageSenderNickname,
|
||||||
|
this.sessionType,
|
||||||
|
this.contentType,
|
||||||
|
this.content,
|
||||||
|
});
|
||||||
|
|
||||||
|
EditedInfo.fromJson(Map<String, dynamic> json) {
|
||||||
|
editerID = json['editerID'];
|
||||||
|
clientMsgID = json['clientMsgID'];
|
||||||
|
editTime = json['editTime'];
|
||||||
|
sourceMessageSendTime = json['sourceMessageSendTime'];
|
||||||
|
sourceMessageSendID = json['sourceMessageSendID'];
|
||||||
|
sourceMessageSenderNickname = json['sourceMessageSenderNickname'];
|
||||||
|
sessionType = json['sessionType'];
|
||||||
|
contentType = json['contentType'];
|
||||||
|
content = json['content'];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
data['editerID'] = this.editerID;
|
||||||
|
data['clientMsgID'] = this.clientMsgID;
|
||||||
|
data['editTime'] = this.editTime;
|
||||||
|
data['sourceMessageSendTime'] = this.sourceMessageSendTime;
|
||||||
|
data['sourceMessageSendID'] = this.sourceMessageSendID;
|
||||||
|
data['sourceMessageSenderNickname'] = this.sourceMessageSenderNickname;
|
||||||
|
data['sessionType'] = this.sessionType;
|
||||||
|
data['contentType'] = this.contentType;
|
||||||
|
data['content'] = this.content;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class AdvancedMessage {
|
class AdvancedMessage {
|
||||||
List<Message>? messageList;
|
List<Message>? messageList;
|
||||||
bool? isEnd;
|
bool? isEnd;
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import 'package:flutter/services.dart';
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
class OpenIM {
|
class OpenIM {
|
||||||
static const version = '3.8.1+2';
|
static const version = '3.8.2+1';
|
||||||
|
|
||||||
static const _channel = MethodChannel('flutter_openim_sdk');
|
static const _channel = MethodChannel('flutter_openim_sdk');
|
||||||
|
|
||||||
|
|||||||
24
pubspec.lock
24
pubspec.lock
@@ -63,18 +63,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker
|
name: leak_tracker
|
||||||
sha256: "7f0df31977cb2c0b88585095d168e689669a2cc9b97c309665e3386f3e9d341a"
|
sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "10.0.4"
|
version: "10.0.5"
|
||||||
leak_tracker_flutter_testing:
|
leak_tracker_flutter_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker_flutter_testing
|
name: leak_tracker_flutter_testing
|
||||||
sha256: "06e98f569d004c1315b991ded39924b21af84cf14cc94791b8aea337d25b57f8"
|
sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.0.3"
|
version: "3.0.5"
|
||||||
leak_tracker_testing:
|
leak_tracker_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -95,18 +95,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: material_color_utilities
|
name: material_color_utilities
|
||||||
sha256: "0e0a020085b65b6083975e499759762399b4475f766c21668c4ecca34ea74e5a"
|
sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.8.0"
|
version: "0.11.1"
|
||||||
meta:
|
meta:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: meta
|
name: meta
|
||||||
sha256: "7687075e408b093f36e6bbf6c91878cc0d4cd10f409506f7bc996f68220b9136"
|
sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.12.0"
|
version: "1.15.0"
|
||||||
path:
|
path:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -164,10 +164,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: test_api
|
name: test_api
|
||||||
sha256: "9955ae474176f7ac8ee4e989dadfb411a58c30415bcfb648fa04b2b8a03afa7f"
|
sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.7.0"
|
version: "0.7.2"
|
||||||
vector_math:
|
vector_math:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -180,10 +180,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: vm_service
|
name: vm_service
|
||||||
sha256: "3923c89304b715fb1eb6423f017651664a03bf5f4b29983627c4da791f74a4ec"
|
sha256: "5c5f338a667b4c644744b661f309fb8080bb94b18a7e91ef1dbd343bed00ed6d"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "14.2.1"
|
version: "14.2.5"
|
||||||
sdks:
|
sdks:
|
||||||
dart: ">=3.3.0 <4.0.0"
|
dart: ">=3.3.0 <4.0.0"
|
||||||
flutter: ">=3.18.0-18.0.pre.54"
|
flutter: ">=3.18.0-18.0.pre.54"
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
name: flutter_openim_sdk
|
name: flutter_openim_sdk
|
||||||
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
|
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
|
||||||
version: 3.8.1+2
|
version: 3.8.2+1
|
||||||
homepage: https://www.openim.io
|
homepage: https://www.openim.io
|
||||||
repository: https://github.com/openimsdk/open-im-sdk-flutter
|
repository: https://github.com/openimsdk/open-im-sdk-flutter
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user