react-native-bluetooth-cross-platform
Version:
Cross-platform bluetooth and wi-fi nearby proximity framework.
83 lines (79 loc) • 1.96 kB
JavaScript
import {
NativeModules,
NativeEventEmitter,
} from 'react-native'
import React from 'react'
var NativeManager = NativeModules.NetworkManager
var NativeEmitter = new NativeEventEmitter(NativeModules.NetworkManager)
class NetworkManager {
// kind can be one of "WIFI", "BT", and "WIFI-BT"
browse(kind) {
NativeManager.browse(kind)
}
// kind can be one of "WIFI", "BT", and "WIFI-BT"
advertise(kind) {
NativeManager.advertise(kind)
}
stopAdvertising() {
NativeManager.stopAdvertising()
}
stopBrowsing() {
NativeManager.stopBrowsing()
}
disconnectFromPeer(peerId) {
NativeManager.disconnectFromPeer(peerId)
}
inviteUser(peerId) {
NativeManager.inviteUser(peerId)
}
sendMessage(message, peerId) {
NativeManager.sendMessage(message, peerId)
}
acceptInvitation(peerId) {
NativeManager.acceptInvitation(peerId)
}
getNearbyPeers(callback) {
NativeManager.getNearbyPeers((peers) => {
callback(peers)
})
}
getConnectedPeers(callback) {
NativeManager.getConnectedPeers((peers) => {
callback(peers)
})
}
/*listener callbacks
peer contains .id (string), type(string), connected(bool), message(string), display name(string)
*/
addPeerDetectedListener(callback) {
return NativeEmitter.addListener(
'detectedUser',
(peer) => callback(peer)
)
}
addPeerLostListener(callback) {
return NativeEmitter.addListener(
'lostUser',
(peer) => callback(peer)
)
}
addReceivedMessageListener(callback) {
return NativeEmitter.addListener(
'messageReceived',
(peer) => callback(peer)
);
}
addInviteListener(callback) {
return NativeEmitter.addListener(
'receivedInvitation',
(peer) => callback(peer)
)
}
addConnectedListener(callback) {
return NativeEmitter.addListener(
'connectedToUser',
(peer) => callback(peer)
)
}
}
module.exports = new NetworkManager()