nativeScript-onesignal-sdk
您令人惊叹的 NativeScript 插件。
npm i --save nativescript-onesignal-sdk

Nativescript Onesignal SDK

一个用于处理 ios 和 android NativeScript 应用程序推送通知的 Onesignal 插件。

先决条件

拥有一个活跃的 Onesignal 应用程序的 Onesignal 账户。

安装

tns plugin add nativescript-onesignal-sdk

使用方法

Angular

不支持

Typescript & Javascript

Android

onesignal_app_idonesignal_google_project_number 两个值作为字符串资源添加

<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">Demo</string>
<string name="onesignal_app_id">your_onesignal_app_id</string>
<string name="onesignal_google_project_number">your_onesignal_google_project_number</string>
</resources>

然后在您的 AndroidManifest.xml 中引用这些值。

注意:在 manifest 根标签中添加 xmlns:tools="http://schemas.android.com/tools"

<meta-data
tools:replace="android:value"
android:name="onesignal_app_id"
android:value="@string/onesignal_app_id"/>


<meta-data
tools:replace="android:value"
android:name="onesignal_google_project_number"
android:value="@string/onesignal_google_project_number"/>

在您的 main.tsapp.js 中添加以下代码

import * as app from "application";
var TnsOneSignal = require("nativescript-onesignal").TnsOneSignal;

if (app.android) {
app.on(app.launchEvent, args => {
TnsOneSignal.startInit(app.android.context).init();
});
}

iOS

在您的 main.tsapp.js 中添加以下代码

import * as app from 'application';
var TnsOneSignal = require('nativescript-onesignal').TnsOneSignal

if (app.ios) {
TnsOneSignal.initWithLaunchOptionsAppIdHandleNotificationReceivedHandleNotificationActionSettings({},
<your-onesignal-app-id>,
(notificationReceived) => {
console.log(notification);
},
(notificationAction) => {
console.log(notification);
});
}

API 参考

iOS API 参考

Android API 参考

示例

npm run plugin.prepare
# iOS
npm run demo.ios
# Android
npm run demo.android

许可证

Apache 许可证第 2 版,2004 年 1 月