An open API service indexing awesome lists of open source software.

https://github.com/devengagelab/engagelab-uts-plugin

engagelab push sdk uts plugin
https://github.com/devengagelab/engagelab-uts-plugin

Last synced: about 1 year ago
JSON representation

engagelab push sdk uts plugin

Awesome Lists containing this project

README

          

# uts-engagelabmtpush

## 兼容性

只支持 Android 和 iOS。

最低支持 iOS12。

## 插件市场地址

## Demo
[Github](https://github.com/DevEngageLab/engagelab-uts-plugin)

## 接入

- 3.在项目中引用插件
```
import { InitPushParams, initPush, setDebugMode, addEventCallBack, EventCallBack, EventCallBackParams, setBadge, SetBadge, getRegistrationId } from "@/uni_modules/engagelab-mtpush"
```

## Android 配置 应用的 nativeResources/android 目录下新增 manifestPlaceholders.json 文件。 内容参考如下,根据自身项目填入正确的值。

```js
{
"ENGAGELAB_PRIVATES_APPKEY" : "xxx",
"ENGAGELAB_PRIVATES_CHANNEL": "xxx",
"ENGAGELAB_PRIVATES_PROCESS": ":remote",
"XIAOMI_APPID" : "MI-xxx",
"XIAOMI_APPKEY" : "MI-xxx",
"MEIZU_APPID" : "MZ-xxx",
"MEIZU_APPKEY" : "MZ-xxx",
"OPPO_APPID" : "OP-xxx",
"OPPO_APPKEY" : "OP-xxx",
"OPPO_APPSECRET" : "OP-xxx",
"VIVO_APPID": "xxx",
"VIVO_APPKEY" : "xxx",
"HONOR_APPID" : "xxx"
}
```

如果支持谷歌通道,在应用的 nativeResources/android 目录下,放入 google-services.json 文件。
如果支持华为通道,在应用的 nativeResources/android 目录下,放入 agconnect-services.json 文件。

#### Android 厂商配置说明
插件支持 OPPO VIVO 魅族 小米 华为 FCM 荣耀七大厂商推送接入,如需接入请对应配置上述厂商信息。

- [厂商通道参数申请指南](https://jiguang-docs.yuque.com/staff-mg3p4r/vc4ysl/ca9ssa1c4izt4b5u?singleDoc#)

## 参考资料
[官方文档](https://www.engagelab.com/push)

# API 说明

## 注册监听

### addEventCallBack(param: EventCallBackParams) : void (android/ios都支持)

集成了 sdk 回调的事件

#### 参数说明
- param:返回的事件数据
- param["event_name"]: 为事件类型
- android:
- "onNotificationStatus":应用通知开关状态回调,Map格式。enable属性:true为打开,false为关闭
- "onConnectStatus":长连接状态回调, Map格式。enable属性:true为打开,false为关闭
- "onNotificationArrived":通知消息到达回调,内容为通知消息体
- "onNotificationClicked":通知消息点击回调,内容为通知消息体
- "onNotificationDeleted":通知消息删除回调,内容为通知消息体
- "onCustomMessage":自定义消息回调,内容为通知消息体
- "onPlatformToken":厂商token消息回调,内容为厂商token消息体
- "onTagMessage":tag操作回调 //todo
- "onAliasMessage":alias操作回调
- "onNotificationUnShow":在前台,通知消息不显示回调(后台下发的通知是前台信息时)
- "onInAppMessageShow": 应用内消息展示
- "onInAppMessageClick": 应用内消息点击
- ios:
- "onNotificationStatus":检测通知权限授权情况。Map格式。enable属性:true为打开,false为关闭。需要先调用getNotiAuth() 接口。
- "onConnectStatus":长连接状态回调, Map格式。enable属性:true为打开,false为关闭
- "onNotificationArrived":通知消息到达回调,内容为通知消息体(同原生平台willPresentNotification回调)
- "onNotificationClicked":通知消息点击回调,内容为通知消息体
- "onCustomMessage":自定义消息回调,内容为通知消息体
- "onTagMessage":tag操作回调 //todo
- "onAliasMessage":alias操作回调
- "onInAppMessageShow": 应用内消息展示
- "onInAppMessageClick": 应用内消息点击
- "onNotiInMessageShow": 增强提醒展示
- "onNotiInMessageClick": 增强提醒点击
- param["event_data"]: 为对应内容,Map格式

#### 代码示例

```js

let eventCallBack = {
callback: (res: EventCallBack) => {
console.log(res);
}
} as EventCallBackParams;
addEventCallBack(eventCallBack);

```

## 初始化

### initPush(param: InitPushParams) (ios/android)

初始化sdk

#### 接口定义

```js
function initPush(param: InitPushParams): void
```

#### 代码示例
```js
// appkey对iOS生效,安卓的appkey需要配置在应用的 nativeResources/android/manifestPlaceholders.json中
let options = {
appkey: '您的appkey',
channel: 'test',
isProduction: false
} as InitPushParams;
initPush(options);
```

## 开启 Debug 模式

### setDebugMode(param: boolean) (android/ios都支持)

设置是否debug模式,debug模式会打印更对详细日志

#### 接口定义

```js
function setDebugMode(paramA : boolean) : void
```

#### 参数说明

- param: 是否调试模式,true为调试模式,false不是

#### 代码示例

```js
setDebugMode(true);//发布前要删除掉
```

## 获取 RegistrationID (android/ios都支持)

### function getRegistrationId(): string

RegistrationID 定义:
获取当前设备的registrationId,Engagelab唯一标识,可同于推送

#### 接口定义

```js
function getRegistrationId(): string
```

#### 返回值

调用此 API 来取得应用程序对应的 RegistrationID。 只有当应用程序成功注册到 MTPush 的服务器时才返回对应的值,否则返回空字符串。

#### 代码示例

```js
const rid = getRegistrationId();
```

## 设置应用角标数量 (android/ios都支持)

### function setBadge(param: number) : void

android: 仅华为/荣耀生效

#### 接口定义

```js
function setBadge(param: number) : void
```

#### 返回值

#### 代码示例

```js
setBadge(2);
```

## 开启fcm测试模式

### testConfigGoogle(enable: boolean) (仅android支持)

设置为true, 可以在国内测试fcm通道,需要在初始化函数之前调用。

该接口只用作测试,正式环境请不要调用该接口!!!

#### 接口定义

```js
export function testConfigGoogle(enable: boolean) : void
```

#### 参数说明

- enable: 是否开启fcm调试模式,true为是,false不是

#### 代码示例

```js
testConfigGoogle(true);
```

## 检测通知授权情况

### getNotiAuth() (仅iOS支持)

调用该函数之前,请先调用 addEventCallBack(param: EventCallBackParams) : void 接口注册事件监听。

回调 event_name 为 "onNotificationStatus" 事件。

#### 接口定义

```js
export function getNotiAuth() : void
```

#### 参数说明

#### 代码示例

```js
getNotiAuth();
```