react-native
अधिसूचना करें
खोज…
परिचय
हम zo0r द्वारा npm मॉड्यूल रिएक्शन-देशी-पुश-नोटिफिकेशन का उपयोग करके देशी ऐप पर प्रतिक्रिया देने के लिए पुश नोटिफिकेशन जोड़ सकते हैं। यह एक क्रॉस प्लेटफॉर्म डेवलपमेंट के लिए सक्षम बनाता है।
स्थापना
npm इंस्टाल - save रिएक्ट-देशी-पुश-नोटिफिकेशन
प्रतिक्रिया-मूल लिंक
टिप्पणियों
अधिक जानकारी के लिए इस मॉड्यूल के GitHub रेपो को देखें।
पुश सूचना सरल सेटअप
नया प्रोजेक्ट PushNotification बनाएं
react-native init PushNotification
Index.android.js में निम्नलिखित डालें
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
Button
} from 'react-native';
import PushNotification from 'react-native-push-notification';
export default class App extends Component {
constructor(props){
super(props);
this.NewNotification = this.NewNotification.bind(this);
}
componentDidMount(){
PushNotification.configure({
// (required) Called when a remote or local notification is opened or received
onNotification: function(notification) {
console.log( 'NOTIFICATION:', notification );
},
// Should the initial notification be popped automatically
// default: true
popInitialNotification: true,
/**
* (optional) default: true
* - Specified if permissions (ios) and token (android and ios) will requested or not,
* - if not, you must call PushNotificationsHandler.requestPermissions() later
*/
requestPermissions: true,
});
}
NewNotification(){
let date = new Date(Date.now() + (this.state.seconds * 1000));
//Fix for IOS
if(Platform.OS == "ios"){
date = date.toISOString();
}
PushNotification.localNotificationSchedule({
message: "My Notification Message", // (required)
date: date,// (optional) for setting delay
largeIcon:""// set this blank for removing large icon
//smallIcon: "ic_notification", // (optional) default: "ic_notification" with fallback for "ic_launcher"
});
}
render() {
return (
<View style={styles.container}>
<Text style={styles.welcome}>
Push Notification
</Text>
<View style={styles.Button} >
<Button
onPress={()=>{this.NewNotification()}}
title="Show Notification"
style={styles.Button}
color="#841584"
accessibilityLabel="Show Notification"
/>
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
welcome: {
fontSize: 20,
textAlign: 'center',
margin: 10,
},
Button:{
margin: 10,
}
});
AppRegistry.registerComponent('PushNotification', () => App);
अधिसूचना से दृश्य पर नेविगेट करना
यहां एक सरल उदाहरण प्रदर्शित किया गया है कि हम अधिसूचना के आधार पर एक विशिष्ट स्क्रीन को कैसे कूद / खोल सकते हैं। उदाहरण के लिए, जब कोई उपयोगकर्ता अधिसूचना पर क्लिक करता है, तो ऐप को होम पेज के बजाय सीधे खुल जाना चाहिए और नोटिफिकेशन पेज पर कूदना चाहिए।
'use strict';
import React, { Component } from 'react';
import {
StyleSheet,
Text,
View,
Navigator,
TouchableOpacity,
AsyncStorage,
BackAndroid,
Platform,
} from 'react-native';
import PushNotification from 'react-native-push-notification';
let initialRoute = { id: 'loginview' }
export default class MainClass extends Component
{
constructor(props)
{
super(props);
this.handleNotification = this.handleNotification.bind(this);
}
handleNotification(notification)
{
console.log('handleNotification');
var notificationId = ''
//your logic to get relevant information from the notification
//here you navigate to a scene in your app based on the notification info
this.navigator.push({ id: Constants.ITEM_VIEW_ID, item: item });
}
componentDidMount()
{
var that = this;
PushNotification.configure({
// (optional) Called when Token is generated (iOS and Android)
onRegister: function(token) {
console.log( 'TOKEN:', token );
},
// (required) Called when a remote or local notification is opened or received
onNotification(notification) {
console.log('onNotification')
console.log( notification );
that.handleNotification(notification);
},
// ANDROID ONLY: (optional) GCM Sender ID.
senderID: "Vizido",
// IOS ONLY (optional): default: all - Permissions to register.
permissions: {
alert: true,
badge: true,
sound: true
},
// Should the initial notification be popped automatically
// default: true
popInitialNotification: true,
/**
* (optional) default: true
* - Specified if permissions (ios) and token (android and ios) will requested or not,
* - if not, you must call PushNotificationsHandler.requestPermissions() later
*/
requestPermissions: true,
});
}
render()
{
return (
<Navigator
ref={(nav) => this.navigator = nav }
initialRoute={initialRoute}
renderScene={this.renderScene.bind(this)}
configureScene={(route) =>
{
if (route.sceneConfig)
{
return route.sceneConfig;
}
return Navigator.SceneConfigs.FadeAndroid;
}
}
/>
);
}
renderScene(route, navigator)
{
switch (route.id)
{
// do your routing here
case 'mainview':
return ( <MainView navigator={navigator} /> );
default:
return ( <MainView navigator={navigator} /> );
}
}
}
Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow