项目fork自 jpush 的 Aurora IMUI
参考demo
npm install react-native-imui --save
react-native link react-native-imui
settings.gradle
中的引用路径:
include ':app', ':react-native-imui'
project(':react-native-imui').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-imui/android')
include ':react-native-imui:chatinput'
include ':react-native-imui:messagelist'
include ':react-native-imui:popuptool'
include ':react-native-imui:emoji'
include ':react-native-imui:photoViewPagerview'
include ':react-native-imui:photoViewPagerview:photodraweeview'
然后在 app 的 build.gradle
中引用:
dependencies {
compile project(':react-native-imui')
}
注意事项(Android):我们使用了 support v4, v7 25.3.1 版本,因此需要将你的 build.gradle 中 buildToolsVersion 及 compiledSdkVersion 改为 25 以上。可以参考 demo 的配置。
-
- 引入 Package:
MainApplication.java
import cn.jiguang.imui.messagelist.ReactIMUIPackage; ... @Override protected List<ReactPackage> getPackages() { return Arrays.<ReactPackage>asList( new MainReactPackage(), new ReactIMUIPackage() ); }
-
- Find PROJECT -> TARGETS -> General -> Embedded Binaries and add RCTAuroraIMUI.framework
- 把
iOSResourcePacket
目录NIMKitEmoticon.bundle
拖到XcodeResources
目录下 - 把
iOSResourcePacket
目录IMGS
拖到XcodeImages.xcassets
下
- Find PROJECT -> TARGETS -> General -> Embedded Binaries and add RCTAuroraIMUI.framework
- 把
使用 MessageList,你需要定义 message
对象和 fromUser
对象。
message
对象格式:
status 必须为以下四个值之一: "send_succeed", "send_failed", "send_going", "download_failed",如果没有定义这个属性, 默认值是 "send_succeed".
message = { // 文本
msgId: "msgid",
status: "send_going",
msgType: "text",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
text: "text"
fromUser: {}
}
message = { // image message
msgId: "msgid",
msgType: "image",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
progress: "progress string"
mediaPath: "image path"
fromUser: {},
extend:{
displayName:"图片发送于2017-12-07 10:07",
imageHeight:"2848.000000",
imageWidth:"4288.000000",
thumbPath:"",
path:"",// 图片的路径
url:""
}
}
message = { // 语音
msgId: "msgid",
msgType: "voice",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
duration: number, // 注意这个值有用户自己设置时长,单位秒
mediaPath: "voice path"
fromUser: {},
extend:{
duration:"3"
isPlayed:false
url:""
}
}
message = { //红包消息
msgId: "msgid",
status: "",
msgType: "redpacket",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
extend: {
comments:"",//祝福语
serialNo:"",//
type:""//红包类型
},
fromUser: {}
}
message = { //红包领取消息
msgId: "msgid",
status: "",
msgType: "redpacketOpen",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
extend: {
serialNo:""
tipMsg:""//红包通知
},
fromUser: {}
}
message = { //转账消息
msgId: "msgid",
status: "",
msgType: "transfer",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
extend: {
amount:"1"
comments:""
serialNo:""
},
fromUser: {}
}
message = { //名片消息
msgId: "msgid",
status: "",
msgType: "card",
isOutgoing: "0", // 0 代表发送者 ,1代表接受者
extend: {
imgPath:""//头像
name:""//昵称
sessionId:""//userId
type:""
},
fromUser: {}
}
fromUser
对象格式:
fromUser = {
_id: ""
name: ""
avatar: "avatar image path" // 这里只能http 路径
}
-
java.lang.RuntimeException: java.lang.RuntimeException: com.android.builder.dexing.DexArchiveMergerException: Unable to merge dex
react-native项目名/android/app/build.gradle
中找到defaultConfig
闭包, 在里面添加multiDexEnabled true
代码。然后在dependencies
中新增依赖implementation 'com.android.support:multidex:1.0.1'
。清空项目即可运行 -
Error:java.util.concurrent.ExecutionException: com.android.tools.aapt2.Aapt2Exception: AAPT error: check logs for details
错误react-native项目名/android/gradle.properties
中,新增android.enableAapt2=false
代码即可解决