mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 20:44:10 +00:00
40 lines
1.1 KiB
JavaScript
40 lines
1.1 KiB
JavaScript
|
/**
|
||
|
* Copyright (c) 2015-present, Facebook, Inc.
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
* This source code is licensed under the BSD-style license found in the
|
||
|
* LICENSE file in the root directory of this source tree. An additional grant
|
||
|
* of patent rights can be found in the PATENTS file in the same directory.
|
||
|
*
|
||
|
* @providesModule Vibration
|
||
|
* @flow
|
||
|
*/
|
||
|
'use strict';
|
||
|
|
||
|
var RCTVibration = require('NativeModules').Vibration;
|
||
|
var Platform = require('Platform');
|
||
|
|
||
|
/**
|
||
|
* The Vibration API is exposed at `Vibration.vibrate()`.
|
||
|
* The vibration is asynchronous so this method will return immediately.
|
||
|
*
|
||
|
* There will be no effect on devices that do not support Vibration, eg. the simulator.
|
||
|
*
|
||
|
* Note for android
|
||
|
* add `<uses-permission android:name="android.permission.VIBRATE"/>` to `AndroidManifest.xml`
|
||
|
*
|
||
|
* Vibration patterns are currently unsupported.
|
||
|
*/
|
||
|
|
||
|
var Vibration = {
|
||
|
vibrate: function(duration: number = 400) {
|
||
|
if (Platform.OS === 'android') {
|
||
|
RCTVibration.vibrate(duration);
|
||
|
} else {
|
||
|
RCTVibration.vibrate();
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
|
||
|
module.exports = Vibration;
|