JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 22
  • Score
    100M100P100Q50971F
  • License MIT

A React Native bridge module for interacting with Apple HealthKit data

Package Exports

  • react-native-apple-healthkit

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (react-native-apple-healthkit) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

react-native-apple-healthkit

A React Native bridge module for interacting with Apple HealthKit data.

Alt text

Getting started

Installation (xcode)

  1. npm install react-native-apple-healthkit@https://github.com/GregWilson/react-native-apple-healthkit.git --save
  2. In XCode, in the project navigator, right click LibrariesAdd Files to [your project's name]
  3. Go to node_modulesreact-native-apple-healthkit and add RCTAppleHealthKit.xcodeproj
  4. In XCode, in the project navigator, select your project. Add libRCTAppleHealthKit.a to your project's Build PhasesLink Binary With Libraries
  5. Click RCTAppleHealthKit.xcodeproj in the project navigator and go the Build Settings tab. Make sure 'All' is toggled on (instead of 'Basic'). In the Search Paths section, look for Header Search Paths and make sure it contains both $(SRCROOT)/../../react-native/React and $(SRCROOT)/../../../React - mark both as recursive.
  6. Compile and have fun

Usage

Just require the react-native-apple-healthkit module and you're ready to go!

var AppleHealthKit = require('react-native-apple-healthkit');

...

let healthKitOptions = {
    permissions: {
        read: ["Height", "Weight", "Steps", "DateOfBirth", "BodyMassIndex"],
        write: ["Weight", "Steps"]
    }
};

AppleHealthKit.initHealthKit(healthKitOptions, (err, res) => {
    if(err) {
        console.log("error initializing healthkit: ", err);
        return;
    }
    console.log("HEALTHKIT INITIALIZED!");
    // ...
});

When the module has been successfully initialized you can read and write HealthKit data

var AppleHealthKit = require('react-native-apple-healthkit');
var _ = require('lodash');

...

AppleHealthKit.getCurrentWeight(null, (err, weight) => {
    if(err){
        console.log("error getting current weight: ", err);
        return;
    }
    weight = _.round(weight,1);
    // do something with the weight...
});

...

let myWeight = 200;
AppleHealthKit.saveWeight({weight:myWeight}, (err, res) => {
    if(err){
        console.log("error saving weight to healthkit: ", err);
        return;
    }
    // weight successfully saved
});

Documentation

Permissions

The available HealthKit permissions to use with initHealthKit

Read Permissions:

Height               HKQuantityTypeIdentifierHeight
Weight               HKQuantityTypeIdentifierBodyMass
BodyFatPercentage    HKQuantityTypeIdentifierBodyFatPercentage
BodyMassIndex        HKQuantityTypeIdentifierBodyMassIndex
LeanBodyMass         HKQuantityTypeIdentifierLeanBodyMass
Steps                HKQuantityTypeIdentifierStepCount
Sex                  HKCharacteristicTypeIdentifierBiologicalSex
DateOfBirth          HKCharacteristicTypeIdentifierDateOfBirth
DietaryEnergy        HKQuantityTypeIdentifierDietaryEnergyConsumed
ActiveEnergy         HKQuantityTypeIdentifierActiveEnergyBurned

Write Permissions:

Height               HKQuantityTypeIdentifierHeight
Weight               HKQuantityTypeIdentifierBodyMass
BodyFatPercentage    HKQuantityTypeIdentifierBodyFatPercentage
BodyMassIndex        HKQuantityTypeIdentifierBodyMassIndex
LeanBodyMass         HKQuantityTypeIdentifierLeanBodyMass
Steps                HKQuantityTypeIdentifierStepCount
DietaryEnergy        HKQuantityTypeIdentifierDietaryEnergyConsumed
ActiveEnergy         HKQuantityTypeIdentifierActiveEnergyBurned
    

Methods

isAvailable : check if HealthKit is available on the device

AppleHealthKit.isAvailable((err: string, available: bool) => {
    if(available){
        // ...
    }
});

initHealthKit : check if HealthKit is available on the device

initHealthKit requires an options object with HealthKit permission settings.

let healthKitOptions = {
    permissions: {
        read: ["Height", "Weight", "Steps", "DateOfBirth", "BodyMassIndex"],
        write: ["Weight"]
    }
};
AppleHealthKit.initHealthKit(healthKitOptions: object, (err: string, res: object) => {
    if(err) {
        console.log("error initializing healthkit: ", err);
        return;
    }
    // healthkit is initialized...
    // now safe to read and write healthkit data...
});

getCurrentWeight : get the most recent weight value

AppleHealthKit.getCurrentWeight(null, (err: string, weight: number) => {
    if(err){
        console.log("error getting current weight: ", err);
        return;
    }
    weight = _.round(weight,1);
    // do something with the weight...
});

saveWeight : save a numeric weight value to HealthKit

saveWeight accepts an object containing a numeric weight value with the key weight:

let saveOptions = {weight: 200}
AppleHealthKit.saveWeight(saveOptions, (err, res) => {
    if(err){
        console.log("error saving weight to healthkit: ", err);
        return;
    }
    // weight successfully saved
});