react-native-ble-plx
Version:
React Native Bluetooth Low Energy library
159 lines (138 loc) • 5.72 kB
JavaScript
'use strict';
import { Descriptor } from './Descriptor';
/**
* Characteristic object.
*/
export class Characteristic {
/**
* Internal BLE Manager handle
* @private
*/
/**
* Characteristic unique identifier
*/
/**
* Characteristic UUID
*/
/**
* Service's ID to which characteristic belongs
*/
/**
* Service's UUID to which characteristic belongs
*/
/**
* Device's ID to which characteristic belongs
*/
/**
* True if characteristic can be read
*/
/**
* True if characteristic can be written with response
*/
/**
* True if characteristic can be written without response
*/
/**
* True if characteristic can monitor value changes.
*/
/**
* True if characteristic is monitoring value changes without ACK.
*/
/**
* True if characteristic is monitoring value changes with ACK.
*/
/**
* Characteristic value if present
*/
/**
* Private constructor used to create instance of {@link Characteristic}.
* @param {NativeCharacteristic} nativeCharacteristic NativeCharacteristic
* @param {BleManager} manager BleManager
* @private
*/
constructor(nativeCharacteristic, manager) {
Object.assign(this, nativeCharacteristic, {
_manager: manager
});
}
/**
* {@link #blemanagerdescriptorsfordevice|bleManager.descriptorsForDevice()} with partially filled arguments.
*
* @returns {Promise<Array<Descriptor>>} Promise which emits array of {@link Descriptor} objects which are
* discovered for this {@link Characteristic}.
*/
descriptors() {
return this._manager._descriptorsForCharacteristic(this.id);
}
/**
* {@link #blemanagerreadcharacteristicfordevice|bleManager.readCharacteristicForDevice()} with partially filled arguments.
*
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Promise<Characteristic>} Promise which emits this {@link Characteristic}. Latest value will be stored
* inside returned object.
*/
read(transactionId) {
return this._manager._readCharacteristic(this.id, transactionId);
}
/**
* {@link #blemanagerwritecharacteristicwithresponsefordevice|bleManager.writeCharacteristicWithResponseForDevice()} with partially filled arguments.
*
* @param {Base64} valueBase64 Value in Base64 format.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Promise<Characteristic>} Promise which emits this {@link Characteristic}. Latest value may
* not be stored inside returned object.
*/
writeWithResponse(valueBase64, transactionId) {
return this._manager._writeCharacteristicWithResponse(this.id, valueBase64, transactionId);
}
/**
* {@link #blemanagerwritecharacteristicwithoutresponsefordevice|bleManager.writeCharacteristicWithoutResponseForDevice()} with partially filled arguments.
*
* @param {Base64} valueBase64 Value in Base64 format.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Promise<Characteristic>} Promise which emits this {@link Characteristic}. Latest value may
* not be stored inside returned object.
*/
writeWithoutResponse(valueBase64, transactionId) {
return this._manager._writeCharacteristicWithoutResponse(this.id, valueBase64, transactionId);
}
/**
* {@link #blemanagermonitorcharacteristicfordevice|bleManager.monitorCharacteristicForDevice()} with partially filled arguments.
*
* @param {function(error: ?BleError, characteristic: ?Characteristic)} listener callback which emits
* this {@link Characteristic} with modified value for each notification.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Subscription} Subscription on which `remove()` function can be called to unsubscribe.
*/
monitor(listener, transactionId) {
return this._manager._monitorCharacteristic(this.id, listener, transactionId);
}
/**
* {@link #blemanagerreaddescriptorfordevice|bleManager.readDescriptorForDevice()} with partially filled arguments.
*
* @param {UUID} descriptorUUID {@link Descriptor} UUID.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|cancelTransaction()} function.
* @returns {Promise<Descriptor>} Promise which emits first {@link Descriptor} object matching specified
* UUID paths. Latest value of {@link Descriptor} will be stored inside returned object.
*/
async readDescriptor(descriptorUUID, transactionId) {
return this._manager._readDescriptorForCharacteristic(this.id, descriptorUUID, transactionId);
}
/**
* {@link #blemanagerwritedescriptorfordevice|bleManager.writeDescriptorForDevice()} with partially filled arguments.
*
* @param {UUID} descriptorUUID Descriptor UUID
* @param {Base64} valueBase64 Value to be set coded in Base64
* @param {?TransactionId} transactionId Transaction handle used to cancel operation
* @returns {Promise<Descriptor>} Descriptor which saved passed value.
*/
async writeDescriptor(descriptorUUID, valueBase64, transactionId) {
return this._manager._writeDescriptorForCharacteristic(this.id, descriptorUUID, valueBase64, transactionId);
}
}
//# sourceMappingURL=Characteristic.js.map