react-native-rook-sdk 2.1.1 → 4.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/README.md +35 -3
- package/RNRookSdk.podspec +22 -0
- package/android/build.gradle +20 -41
- package/android/gradle.properties +5 -5
- package/android/src/main/AndroidManifest.xml +1 -2
- package/android/src/main/java/com/rooksdk/RookSdkModule.kt +11 -222
- package/android/src/main/java/com/rooksdk/RookSdkPackage.kt +24 -33
- package/ios/DateHelper.swift +55 -0
- package/ios/Encodable.swift +25 -0
- package/ios/EncodableDataSource.swift +5 -6
- package/ios/EncodableDataSourceAuthorizer.swift +4 -5
- package/ios/HearRateMapper.swift +42 -0
- package/ios/RookBackground.swift +35 -0
- package/ios/RookConfiguration.swift +116 -0
- package/ios/RookData.swift +170 -0
- package/ios/RookEntry.swift +61 -0
- package/ios/RookPermissions.swift +78 -0
- package/ios/RookSdk-Bridging-Header.h +12 -0
- package/ios/RookSdk.h +14 -2
- package/ios/RookSdk.mm +549 -81
- package/ios/RookSources.swift +74 -116
- package/ios/RookSync.swift +126 -34
- package/ios/boost-boost_privacy-Bridging-Header.h +4 -0
- package/lib/module/NativeRookSdk.js +96 -0
- package/lib/module/NativeRookSdk.js.map +1 -0
- package/lib/module/context/RookSyncGateContext.js +2 -0
- package/lib/module/context/RookSyncGateContext.js.map +1 -1
- package/lib/module/context/RookSyncGateProvider.js +16 -15
- package/lib/module/context/RookSyncGateProvider.js.map +1 -1
- package/lib/module/context/RookSyncGateReducer.js +2 -0
- package/lib/module/context/RookSyncGateReducer.js.map +1 -1
- package/lib/module/context/RookSyncGateTypes.js +2 -0
- package/lib/module/hooks/useRookAPISources.js +66 -0
- package/lib/module/hooks/useRookAPISources.js.map +1 -0
- package/lib/module/hooks/useRookAndroidBackgroundSteps.js +12 -25
- package/lib/module/hooks/useRookAndroidBackgroundSteps.js.map +1 -1
- package/lib/module/hooks/useRookAppleHealth.js +11 -23
- package/lib/module/hooks/useRookAppleHealth.js.map +1 -1
- package/lib/module/hooks/useRookConfiguration.js +10 -109
- package/lib/module/hooks/useRookConfiguration.js.map +1 -1
- package/lib/module/hooks/useRookData.js +35 -33
- package/lib/module/hooks/useRookData.js.map +1 -1
- package/lib/module/hooks/useRookHealthConnect.js +9 -10
- package/lib/module/hooks/useRookHealthConnect.js.map +1 -1
- package/lib/module/hooks/useRookPermissions.js +39 -77
- package/lib/module/hooks/useRookPermissions.js.map +1 -1
- package/lib/module/hooks/useRookSamsungHealth.js +35 -0
- package/lib/module/hooks/useRookSamsungHealth.js.map +1 -0
- package/lib/module/hooks/useRookSync.js +23 -31
- package/lib/module/hooks/useRookSync.js.map +1 -1
- package/lib/module/hooks/useRookVariables.js +24 -18
- package/lib/module/hooks/useRookVariables.js.map +1 -1
- package/lib/module/index.js +18 -5
- package/lib/module/index.js.map +1 -1
- package/lib/module/modules/hook/useRookAutoSync.js +22 -36
- package/lib/module/modules/hook/useRookAutoSync.js.map +1 -1
- package/lib/module/modules/types/sendMessageBroadcast.js +1 -1
- package/lib/module/modules/utils/errors.js +2 -0
- package/lib/module/modules/utils/errors.js.map +1 -1
- package/lib/module/package.json +1 -0
- package/lib/module/types/ActivityEvent.js +2 -0
- package/lib/module/types/AppleHealthPermissions.js +53 -0
- package/lib/module/types/AppleHealthPermissions.js.map +1 -0
- package/lib/module/types/AuthorizedSources.js +2 -0
- package/lib/module/types/BodySummary.js +2 -0
- package/lib/module/types/DataSource.js +10 -0
- package/lib/module/types/DataSource.js.map +1 -1
- package/lib/module/types/HeartRateEvent.js +2 -0
- package/lib/{commonjs/types/DataSource.js.map → module/types/HeartRateEvent.js.map} +1 -1
- package/lib/module/types/PermissionsType.js +1 -1
- package/lib/module/types/PhysicalSummary.js +2 -0
- package/lib/module/types/Rook.js +2 -0
- package/lib/{commonjs/types/SyncTypes.js.map → module/types/Rook.js.map} +1 -1
- package/lib/module/types/SDKSources.js +2 -0
- package/lib/module/types/SDKSources.js.map +1 -1
- package/lib/module/types/SamsungHealthPermissions.js +3 -0
- package/lib/module/types/SamsungHealthPermissions.js.map +1 -1
- package/lib/module/types/SleepSummary.js +2 -0
- package/lib/module/types/SummaryTypes.js +1 -1
- package/lib/module/types/SyncTypes.js +28 -1
- package/lib/module/types/SyncTypes.js.map +1 -1
- package/lib/module/utils/isModuleReady.js +2 -0
- package/lib/module/utils/isModuleReady.js.map +1 -1
- package/lib/module/utils/isRunningOnAndroid.js +2 -0
- package/lib/module/utils/isRunningOnAndroid.js.map +1 -1
- package/lib/module/utils/isRunningOniOS.js +2 -0
- package/lib/module/utils/isRunningOniOS.js.map +1 -1
- package/lib/module/utils/isValidDate.js +2 -0
- package/lib/module/utils/isValidDate.js.map +1 -1
- package/lib/typescript/package.json +1 -0
- package/lib/typescript/src/NativeRookSdk.d.ts +190 -0
- package/lib/typescript/src/NativeRookSdk.d.ts.map +1 -0
- package/lib/typescript/src/context/RookSyncGateContext.d.ts.map +1 -1
- package/lib/typescript/src/context/RookSyncGateProvider.d.ts.map +1 -1
- package/lib/typescript/src/context/RookSyncGateReducer.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookAPISources.d.ts +15 -0
- package/lib/typescript/src/hooks/useRookAPISources.d.ts.map +1 -0
- package/lib/typescript/src/hooks/useRookAndroidBackgroundSteps.d.ts +0 -1
- package/lib/typescript/src/hooks/useRookAndroidBackgroundSteps.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookAppleHealth.d.ts +1 -2
- package/lib/typescript/src/hooks/useRookAppleHealth.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookConfiguration.d.ts +0 -8
- package/lib/typescript/src/hooks/useRookConfiguration.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookData.d.ts +2 -0
- package/lib/typescript/src/hooks/useRookData.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookHealthConnect.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookPermissions.d.ts +11 -12
- package/lib/typescript/src/hooks/useRookPermissions.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookSamsungHealth.d.ts +7 -0
- package/lib/typescript/src/hooks/useRookSamsungHealth.d.ts.map +1 -0
- package/lib/typescript/src/hooks/useRookSync.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useRookVariables.d.ts.map +1 -1
- package/lib/typescript/src/index.d.ts +19 -4
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/modules/hook/useRookAutoSync.d.ts.map +1 -1
- package/lib/typescript/src/types/AppleHealthPermissions.d.ts +50 -0
- package/lib/typescript/src/types/AppleHealthPermissions.d.ts.map +1 -0
- package/lib/typescript/src/types/AuthorizedSources.d.ts +3 -3
- package/lib/typescript/src/types/AuthorizedSources.d.ts.map +1 -1
- package/lib/typescript/src/types/DataSource.d.ts +8 -1
- package/lib/typescript/src/types/DataSource.d.ts.map +1 -1
- package/lib/typescript/src/types/HeartRateEvent.d.ts +24 -0
- package/lib/typescript/src/types/HeartRateEvent.d.ts.map +1 -0
- package/lib/typescript/src/types/PermissionsType.d.ts +0 -4
- package/lib/typescript/src/types/PermissionsType.d.ts.map +1 -1
- package/lib/typescript/src/types/Rook.d.ts +9 -0
- package/lib/typescript/src/types/Rook.d.ts.map +1 -0
- package/lib/typescript/src/types/SamsungHealthPermissions.d.ts +1 -0
- package/lib/typescript/src/types/SamsungHealthPermissions.d.ts.map +1 -1
- package/lib/typescript/src/types/SyncTypes.d.ts +28 -5
- package/lib/typescript/src/types/SyncTypes.d.ts.map +1 -1
- package/lib/typescript/src/utils/isModuleReady.d.ts.map +1 -1
- package/lib/typescript/src/utils/isValidDate.d.ts.map +1 -1
- package/package.json +94 -98
- package/src/NativeRookSdk.ts +282 -0
- package/{lib/commonjs/context/RookSyncGateContext.js → src/context/RookSyncGateContext.ts} +10 -13
- package/src/context/RookSyncGateProvider.tsx +78 -0
- package/{lib/commonjs/context/RookSyncGateReducer.js → src/context/RookSyncGateReducer.ts} +12 -33
- package/src/context/RookSyncGateTypes.ts +34 -0
- package/src/hooks/useRookAPISources.ts +83 -0
- package/src/hooks/useRookAndroidBackgroundSteps.ts +81 -0
- package/src/hooks/useRookAppleHealth.ts +55 -0
- package/src/hooks/useRookConfiguration.ts +82 -0
- package/src/hooks/useRookData.ts +122 -0
- package/src/hooks/useRookHealthConnect.ts +59 -0
- package/src/hooks/useRookPermissions.ts +224 -0
- package/src/hooks/useRookSamsungHealth.ts +37 -0
- package/src/hooks/useRookSync.ts +157 -0
- package/src/hooks/useRookVariables.ts +77 -0
- package/src/index.tsx +28 -0
- package/src/modules/hook/useRookAutoSync.ts +305 -0
- package/src/modules/types/sendMessageBroadcast.ts +5 -0
- package/src/modules/utils/errors.ts +9 -0
- package/src/types/ActivityEvent.ts +159 -0
- package/src/types/AppleHealthPermissions.ts +49 -0
- package/src/types/AuthorizedSources.ts +33 -0
- package/src/types/BodySummary.ts +116 -0
- package/src/types/DataSource.ts +16 -0
- package/src/types/HeartRateEvent.ts +26 -0
- package/src/types/PermissionsType.ts +9 -0
- package/src/types/PhysicalSummary.ts +84 -0
- package/src/types/Rook.ts +8 -0
- package/src/types/SDKSources.ts +5 -0
- package/src/types/SamsungHealthPermissions.ts +16 -0
- package/src/types/SleepSummary.ts +66 -0
- package/src/types/SummaryTypes.ts +70 -0
- package/src/types/SyncTypes.ts +63 -0
- package/{lib/commonjs/utils/isModuleReady.js → src/utils/isModuleReady.ts} +4 -10
- package/src/utils/isRunningOnAndroid.ts +10 -0
- package/src/utils/isRunningOniOS.ts +10 -0
- package/{lib/commonjs/utils/isValidDate.js → src/utils/isValidDate.ts} +5 -10
- package/android/src/main/AndroidManifestNew.xml +0 -36
- package/android/src/main/java/com/rooksdk/broadcasts/AndroidPermissionsReceiverTransmitter.kt +0 -65
- package/android/src/main/java/com/rooksdk/broadcasts/HealthConnectPermissionsReceiverTransmitter.kt +0 -70
- package/android/src/main/java/com/rooksdk/broadcasts/SamsungHealthPermissionsReceiverTransmitter.kt +0 -52
- package/android/src/main/java/com/rooksdk/modules/RookBackgroundSyncModule.kt +0 -85
- package/android/src/main/java/com/rooksdk/modules/RookConfigurationModule.kt +0 -148
- package/android/src/main/java/com/rooksdk/modules/RookLocalData.kt +0 -247
- package/android/src/main/java/com/rooksdk/modules/RookPermissionsModule.kt +0 -309
- package/android/src/main/java/com/rooksdk/modules/RookStepsModule.kt +0 -105
- package/android/src/main/java/com/rooksdk/modules/RookSyncModule.kt +0 -496
- package/android/src/main/java/com/rooksdk/utils/DatasourcesUtils.kt +0 -63
- package/android/src/main/java/com/rooksdk/utils/PermissionConversion.kt +0 -21
- package/android/src/main/java/com/rooksdk/utils/ReadableToWritable.kt +0 -64
- package/android/src/main/java/com/rooksdk/utils/RookDateTime.kt +0 -20
- package/android/src/main/java/com/rooksdk/utils/SamsungAvailability.kt +0 -21
- package/android/src/main/java/com/rooksdk/utils/Source.kt +0 -6
- package/android/src/main/java/com/rooksdk/utils/StringToSyncType.kt +0 -58
- package/android/src/main/java/com/rooksdk/utils/serializers/InstantSerializer.kt +0 -19
- package/android/src/main/java/com/rooksdk/utils/serializers/LocalDateSerializer.kt +0 -21
- package/android/src/main/res/drawable/ic_health_connect.xml +0 -19
- package/android/src/main/res/values/themes.xml +0 -3
- package/ios/EncodableRookDataSource.swift +0 -36
- package/ios/EncodableStatusDataSources.swift +0 -47
- package/ios/RookBackgroundModule.h +0 -5
- package/ios/RookBackgroundModule.mm +0 -89
- package/ios/RookConfigurationModule.h +0 -5
- package/ios/RookConfigurationModule.mm +0 -163
- package/ios/RookExternalModule.h +0 -5
- package/ios/RookExternalModule.m +0 -27
- package/ios/RookLocalData.swift +0 -152
- package/ios/RookPermissionsModule.h +0 -5
- package/ios/RookPermissionsModule.mm +0 -180
- package/ios/RookSourcesModule.h +0 -5
- package/ios/RookSourcesModule.mm +0 -67
- package/ios/RookSync.h +0 -5
- package/ios/RookSync.m +0 -27
- package/ios/RookSyncModule.h +0 -5
- package/ios/RookSyncModule.mm +0 -476
- package/ios/SwiftTest.swift +0 -18
- package/ios/react-native-rook-sdk-Bridging-Header.h +0 -12
- package/lib/commonjs/context/RookSyncGateContext.js.map +0 -1
- package/lib/commonjs/context/RookSyncGateProvider.js +0 -98
- package/lib/commonjs/context/RookSyncGateProvider.js.map +0 -1
- package/lib/commonjs/context/RookSyncGateReducer.js.map +0 -1
- package/lib/commonjs/context/RookSyncGateTypes.js +0 -6
- package/lib/commonjs/context/RookSyncGateTypes.js.map +0 -1
- package/lib/commonjs/context/index.js +0 -14
- package/lib/commonjs/context/index.js.map +0 -1
- package/lib/commonjs/hooks/index.js +0 -90
- package/lib/commonjs/hooks/index.js.map +0 -1
- package/lib/commonjs/hooks/useRookAndroidBackgroundSteps.js +0 -100
- package/lib/commonjs/hooks/useRookAndroidBackgroundSteps.js.map +0 -1
- package/lib/commonjs/hooks/useRookAppleHealth.js +0 -74
- package/lib/commonjs/hooks/useRookAppleHealth.js.map +0 -1
- package/lib/commonjs/hooks/useRookAppleHealthVariables.js +0 -48
- package/lib/commonjs/hooks/useRookAppleHealthVariables.js.map +0 -1
- package/lib/commonjs/hooks/useRookConfiguration.js +0 -188
- package/lib/commonjs/hooks/useRookConfiguration.js.map +0 -1
- package/lib/commonjs/hooks/useRookData.js +0 -100
- package/lib/commonjs/hooks/useRookData.js.map +0 -1
- package/lib/commonjs/hooks/useRookDataSources.js +0 -118
- package/lib/commonjs/hooks/useRookDataSources.js.map +0 -1
- package/lib/commonjs/hooks/useRookEvents.js +0 -225
- package/lib/commonjs/hooks/useRookEvents.js.map +0 -1
- package/lib/commonjs/hooks/useRookHealthConnect.js +0 -70
- package/lib/commonjs/hooks/useRookHealthConnect.js.map +0 -1
- package/lib/commonjs/hooks/useRookPermissions.js +0 -226
- package/lib/commonjs/hooks/useRookPermissions.js.map +0 -1
- package/lib/commonjs/hooks/useRookSummaries.js +0 -85
- package/lib/commonjs/hooks/useRookSummaries.js.map +0 -1
- package/lib/commonjs/hooks/useRookSync.js +0 -147
- package/lib/commonjs/hooks/useRookSync.js.map +0 -1
- package/lib/commonjs/hooks/useRookVariables.js +0 -69
- package/lib/commonjs/hooks/useRookVariables.js.map +0 -1
- package/lib/commonjs/index.js +0 -56
- package/lib/commonjs/index.js.map +0 -1
- package/lib/commonjs/modules/hook/useRookAutoSync.js +0 -262
- package/lib/commonjs/modules/hook/useRookAutoSync.js.map +0 -1
- package/lib/commonjs/modules/types/sendMessageBroadcast.js +0 -2
- package/lib/commonjs/modules/types/sendMessageBroadcast.js.map +0 -1
- package/lib/commonjs/modules/utils/errors.js +0 -12
- package/lib/commonjs/modules/utils/errors.js.map +0 -1
- package/lib/commonjs/types/ActivityEvent.js +0 -6
- package/lib/commonjs/types/ActivityEvent.js.map +0 -1
- package/lib/commonjs/types/AuthorizedSources.js +0 -2
- package/lib/commonjs/types/AuthorizedSources.js.map +0 -1
- package/lib/commonjs/types/BodySummary.js +0 -6
- package/lib/commonjs/types/BodySummary.js.map +0 -1
- package/lib/commonjs/types/DataSource.js +0 -2
- package/lib/commonjs/types/PermissionsType.js +0 -2
- package/lib/commonjs/types/PermissionsType.js.map +0 -1
- package/lib/commonjs/types/PhysicalSummary.js +0 -6
- package/lib/commonjs/types/PhysicalSummary.js.map +0 -1
- package/lib/commonjs/types/SDKSources.js +0 -13
- package/lib/commonjs/types/SDKSources.js.map +0 -1
- package/lib/commonjs/types/SamsungHealthPermissions.js +0 -23
- package/lib/commonjs/types/SamsungHealthPermissions.js.map +0 -1
- package/lib/commonjs/types/SleepSummary.js +0 -6
- package/lib/commonjs/types/SleepSummary.js.map +0 -1
- package/lib/commonjs/types/SummaryTypes.js +0 -2
- package/lib/commonjs/types/SummaryTypes.js.map +0 -1
- package/lib/commonjs/types/SyncTypes.js +0 -6
- package/lib/commonjs/utils/credentials.js +0 -12
- package/lib/commonjs/utils/credentials.js.map +0 -1
- package/lib/commonjs/utils/getNativeModule.js +0 -29
- package/lib/commonjs/utils/getNativeModule.js.map +0 -1
- package/lib/commonjs/utils/getRookModule.js +0 -28
- package/lib/commonjs/utils/getRookModule.js.map +0 -1
- package/lib/commonjs/utils/isModuleReady.js.map +0 -1
- package/lib/commonjs/utils/isRunningOnAndroid.js +0 -15
- package/lib/commonjs/utils/isRunningOnAndroid.js.map +0 -1
- package/lib/commonjs/utils/isRunningOniOS.js +0 -15
- package/lib/commonjs/utils/isRunningOniOS.js.map +0 -1
- package/lib/commonjs/utils/isValidDate.js.map +0 -1
- package/lib/commonjs/utils/nativeModules.js +0 -28
- package/lib/commonjs/utils/nativeModules.js.map +0 -1
- package/lib/commonjs/utils/packageInfo.js +0 -13
- package/lib/commonjs/utils/packageInfo.js.map +0 -1
- package/lib/module/context/index.js +0 -2
- package/lib/module/context/index.js.map +0 -1
- package/lib/module/hooks/index.js +0 -13
- package/lib/module/hooks/index.js.map +0 -1
- package/lib/module/hooks/useRookAppleHealthVariables.js +0 -41
- package/lib/module/hooks/useRookAppleHealthVariables.js.map +0 -1
- package/lib/module/hooks/useRookDataSources.js +0 -110
- package/lib/module/hooks/useRookDataSources.js.map +0 -1
- package/lib/module/hooks/useRookEvents.js +0 -218
- package/lib/module/hooks/useRookEvents.js.map +0 -1
- package/lib/module/hooks/useRookSummaries.js +0 -78
- package/lib/module/hooks/useRookSummaries.js.map +0 -1
- package/lib/module/utils/credentials.js +0 -6
- package/lib/module/utils/credentials.js.map +0 -1
- package/lib/module/utils/getNativeModule.js +0 -23
- package/lib/module/utils/getNativeModule.js.map +0 -1
- package/lib/module/utils/getRookModule.js +0 -22
- package/lib/module/utils/getRookModule.js.map +0 -1
- package/lib/module/utils/nativeModules.js +0 -22
- package/lib/module/utils/nativeModules.js.map +0 -1
- package/lib/module/utils/packageInfo.js +0 -7
- package/lib/module/utils/packageInfo.js.map +0 -1
- package/lib/typescript/src/context/index.d.ts +0 -2
- package/lib/typescript/src/context/index.d.ts.map +0 -1
- package/lib/typescript/src/hooks/index.d.ts +0 -13
- package/lib/typescript/src/hooks/index.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useRookAppleHealthVariables.d.ts +0 -15
- package/lib/typescript/src/hooks/useRookAppleHealthVariables.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useRookDataSources.d.ts +0 -22
- package/lib/typescript/src/hooks/useRookDataSources.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useRookEvents.d.ts +0 -26
- package/lib/typescript/src/hooks/useRookEvents.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useRookSummaries.d.ts +0 -14
- package/lib/typescript/src/hooks/useRookSummaries.d.ts.map +0 -1
- package/lib/typescript/src/utils/credentials.d.ts +0 -5
- package/lib/typescript/src/utils/credentials.d.ts.map +0 -1
- package/lib/typescript/src/utils/getNativeModule.d.ts +0 -10
- package/lib/typescript/src/utils/getNativeModule.d.ts.map +0 -1
- package/lib/typescript/src/utils/getRookModule.d.ts +0 -9
- package/lib/typescript/src/utils/getRookModule.d.ts.map +0 -1
- package/lib/typescript/src/utils/nativeModules.d.ts +0 -23
- package/lib/typescript/src/utils/nativeModules.d.ts.map +0 -1
- package/lib/typescript/src/utils/packageInfo.d.ts +0 -6
- package/lib/typescript/src/utils/packageInfo.d.ts.map +0 -1
- package/react-native-rook-sdk.podspec +0 -45
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["rookSyncGateReducer","state","action","type","ready","environment","clientUUID","password","userID","enableLogs","permissions"],"sourceRoot":"../../../src","sources":["context/RookSyncGateReducer.ts"],"mappings":"AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMA,mBAAmB,GAAGA,CACjCC,KAAwB,EACxBC,MAAc,KACQ;EACtB,QAAQA,MAAM,CAACC,IAAI;IACjB,KAAK,WAAW;MACd,OAAO;QAAE,GAAGF,KAAK;QAAEG,KAAK,EAAEF,MAAM,CAACE;MAAM,CAAC;IAC1C,KAAK,sBAAsB;MACzB,OAAO;QAAE,GAAGH,KAAK;QAAEI,WAAW,EAAEH,MAAM,CAACG;MAAY,CAAC;IACtD,KAAK,iBAAiB;MACpB,OAAO;QAAE,GAAGJ,KAAK;QAAEK,UAAU,EAAEJ,MAAM,CAACI;MAAW,CAAC;IACpD,KAAK,cAAc;MACjB,OAAO;QAAE,GAAGL,KAAK;QAAEM,QAAQ,EAAEL,MAAM,CAACK;MAAS,CAAC;IAChD,KAAK,aAAa;MAChB,OAAO;QAAE,GAAGN,KAAK;QAAEO,MAAM,EAAEN,MAAM,CAACM;MAAO,CAAC;IAC5C,KAAK,iBAAiB;MACpB,OAAO;QAAE,GAAGP,KAAK;QAAEQ,UAAU,EAAEP,MAAM,CAACO;MAAW,CAAC;IACpD,KAAK,iBAAiB;MACpB,OAAO;QACL,GAAGR,KAAK;QACRS,WAAW,EAAET,KAAK,CAACS,WAAW,GAAG;MACnC,CAAC;IACH;MACE,OAAOT,KAAK;EAChB;AACF,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["rookSyncGateReducer","state","action","type","ready","environment","clientUUID","password","userID","enableLogs","permissions"],"sourceRoot":"../../../src","sources":["context/RookSyncGateReducer.ts"],"mappings":";;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMA,mBAAmB,GAAGA,CACjCC,KAAwB,EACxBC,MAAc,KACQ;EACtB,QAAQA,MAAM,CAACC,IAAI;IACjB,KAAK,WAAW;MACd,OAAO;QAAE,GAAGF,KAAK;QAAEG,KAAK,EAAEF,MAAM,CAACE;MAAM,CAAC;IAC1C,KAAK,sBAAsB;MACzB,OAAO;QAAE,GAAGH,KAAK;QAAEI,WAAW,EAAEH,MAAM,CAACG;MAAY,CAAC;IACtD,KAAK,iBAAiB;MACpB,OAAO;QAAE,GAAGJ,KAAK;QAAEK,UAAU,EAAEJ,MAAM,CAACI;MAAW,CAAC;IACpD,KAAK,cAAc;MACjB,OAAO;QAAE,GAAGL,KAAK;QAAEM,QAAQ,EAAEL,MAAM,CAACK;MAAS,CAAC;IAChD,KAAK,aAAa;MAChB,OAAO;QAAE,GAAGN,KAAK;QAAEO,MAAM,EAAEN,MAAM,CAACM;MAAO,CAAC;IAC5C,KAAK,iBAAiB;MACpB,OAAO;QAAE,GAAGP,KAAK;QAAEQ,UAAU,EAAEP,MAAM,CAACO;MAAW,CAAC;IACpD,KAAK,iBAAiB;MACpB,OAAO;QACL,GAAGR,KAAK;QACRS,WAAW,EAAET,KAAK,CAACS,WAAW,GAAG;MACnC,CAAC;IACH;MACE,OAAOT,KAAK;EAChB;AACF,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import RookSdk from "../NativeRookSdk.js";
|
|
4
|
+
import { isModuleReady } from "../utils/isModuleReady.js";
|
|
5
|
+
import { Platform } from 'react-native';
|
|
6
|
+
import { useRookSyncGateContext } from "../context/RookSyncGateContext.js";
|
|
7
|
+
/**
|
|
8
|
+
* The `useRookDataSources` hook provides functionality to interact with data sources in Rook,
|
|
9
|
+
* including retrieving available data sources, presenting a connections page, and revoking user
|
|
10
|
+
* authorization for a specific data source.
|
|
11
|
+
* @returns An object is being returned from the `useRookDataSources` hook to allow the user to access to the sources API
|
|
12
|
+
*/
|
|
13
|
+
export const useRookAPISources = () => {
|
|
14
|
+
const {
|
|
15
|
+
state: {
|
|
16
|
+
ready
|
|
17
|
+
}
|
|
18
|
+
} = useRookSyncGateContext();
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* The function `revokeDataSource` revokes user authorization for the specified data source.
|
|
22
|
+
* @param {DataSourceType} type - The `type` parameter in the `revokeDataSource` function represents
|
|
23
|
+
* the type of data source that you want to revoke access to. It is of type `DataSourceType`.
|
|
24
|
+
* @returns A Promise<boolean> is being returned from the `revokeDataSource` function.
|
|
25
|
+
*/
|
|
26
|
+
const revokeDataSource = (userid, type) => {
|
|
27
|
+
isModuleReady(ready);
|
|
28
|
+
return RookSdk.revokeDataSource(userid, type);
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Retrieves the authorization status for a specific data source linked to a given user.
|
|
33
|
+
* If the user is not authorized, an authorization URL is provided to start the process.
|
|
34
|
+
* If the user is already authorized, the response will indicate "authorized": true and no authorization URL will be
|
|
35
|
+
* returned. The redirect_url parameter can be used to specify where the user should be redirected
|
|
36
|
+
* after completing the authorization.
|
|
37
|
+
* @returns The function `getDataSourceAuthorizer` is returning a `DataSourceAuthorizer` object after
|
|
38
|
+
* parsing the response from `rookSync.current.getDataSourceAuthorizer()` as JSON.
|
|
39
|
+
*/
|
|
40
|
+
const getDataSourceAuthorizer = async props => {
|
|
41
|
+
const response = await RookSdk.getDataSourceAuthorizer(props);
|
|
42
|
+
if (Platform.OS === 'android') return JSON.parse(response);
|
|
43
|
+
return response;
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* The function `getAuthorizedDataSources` returns authorized data sources after checking ROOK services
|
|
48
|
+
* in case of apple health, health connect and android this only determines if the user
|
|
49
|
+
* is connected not if the user granted permissions.
|
|
50
|
+
* @returns The function `getAuthorizedDataSources` is returning a Promise that will resolve to the
|
|
51
|
+
* result of calling `rookSync.current.getAuthorizedDataSources()`.
|
|
52
|
+
*/
|
|
53
|
+
const getAuthorizedDataSourcesV2 = async userid => {
|
|
54
|
+
isModuleReady(ready);
|
|
55
|
+
if (Platform.OS !== 'android') return RookSdk.getAuthorizedDataSourcesV2(userid);
|
|
56
|
+
const response = await RookSdk.getAuthorizedDataSourcesV2(userid);
|
|
57
|
+
return JSON.parse(response);
|
|
58
|
+
};
|
|
59
|
+
return {
|
|
60
|
+
ready,
|
|
61
|
+
revokeDataSource,
|
|
62
|
+
getDataSourceAuthorizer,
|
|
63
|
+
getAuthorizedDataSourcesV2
|
|
64
|
+
};
|
|
65
|
+
};
|
|
66
|
+
//# sourceMappingURL=useRookAPISources.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["RookSdk","isModuleReady","Platform","useRookSyncGateContext","useRookAPISources","state","ready","revokeDataSource","userid","type","getDataSourceAuthorizer","props","response","OS","JSON","parse","getAuthorizedDataSourcesV2"],"sourceRoot":"../../../src","sources":["hooks/useRookAPISources.ts"],"mappings":";;AAAA,OAAOA,OAAO,MAAM,qBAAkB;AACtC,SAASC,aAAa,QAAQ,2BAAwB;AACtD,SAASC,QAAQ,QAAQ,cAAc;AACvC,SAASC,sBAAsB,QAAQ,mCAAgC;AAQvE;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,iBAAiB,GAAGA,CAAA,KAAM;EACrC,MAAM;IACJC,KAAK,EAAE;MAAEC;IAAM;EACjB,CAAC,GAAGH,sBAAsB,CAAC,CAAC;;EAE5B;AACF;AACA;AACA;AACA;AACA;EACE,MAAMI,gBAAgB,GAAGA,CACvBC,MAAc,EACdC,IAAmB,KACE;IACrBR,aAAa,CAACK,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACO,gBAAgB,CAACC,MAAM,EAAEC,IAAI,CAAC;EAC/C,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,MAAMC,uBAAuB,GAAG,MAC9BC,KAAsB,IACY;IAClC,MAAMC,QAAQ,GAAG,MAAMZ,OAAO,CAACU,uBAAuB,CAACC,KAAK,CAAC;IAE7D,IAAIT,QAAQ,CAACW,EAAE,KAAK,SAAS,EAC3B,OAAOC,IAAI,CAACC,KAAK,CAACH,QAAe,CAAC;IAEpC,OAAOA,QAAQ;EACjB,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;EACE,MAAMI,0BAA0B,GAAG,MACjCR,MAAc,IACkB;IAChCP,aAAa,CAACK,KAAK,CAAC;IAEpB,IAAIJ,QAAQ,CAACW,EAAE,KAAK,SAAS,EAC3B,OAAOb,OAAO,CAACgB,0BAA0B,CAACR,MAAM,CAAC;IAEnD,MAAMI,QAAQ,GAAG,MAAMZ,OAAO,CAACgB,0BAA0B,CAACR,MAAM,CAAC;IACjE,OAAOM,IAAI,CAACC,KAAK,CAACH,QAAe,CAAC;EACpC,CAAC;EAED,OAAO;IACLN,KAAK;IACLC,gBAAgB;IAChBG,uBAAuB;IACvBM;EACF,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import
|
|
6
|
-
import
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import RookSdk from "../NativeRookSdk.js";
|
|
4
|
+
import { useRookSyncGateContext } from "../context/RookSyncGateContext.js";
|
|
5
|
+
import { isModuleReady } from "../utils/isModuleReady.js";
|
|
6
|
+
import isRunningOnAndroid from "../utils/isRunningOnAndroid.js";
|
|
7
7
|
|
|
8
8
|
/**
|
|
9
9
|
* The `useRookAndroidBackgroundSteps` function provides various methods for managing and retrieving
|
|
@@ -12,7 +12,6 @@ import nativeModules from '../utils/nativeModules';
|
|
|
12
12
|
* control de steps sync
|
|
13
13
|
*/
|
|
14
14
|
export const useRookAndroidBackgroundSteps = () => {
|
|
15
|
-
const rookSync = useRef(getNativeModule(nativeModules.android.STEPS));
|
|
16
15
|
const {
|
|
17
16
|
state: {
|
|
18
17
|
ready
|
|
@@ -26,7 +25,7 @@ export const useRookAndroidBackgroundSteps = () => {
|
|
|
26
25
|
const isStepsAvailable = async () => {
|
|
27
26
|
isRunningOnAndroid();
|
|
28
27
|
isModuleReady(ready);
|
|
29
|
-
return
|
|
28
|
+
return RookSdk.isStepsAvailable();
|
|
30
29
|
};
|
|
31
30
|
|
|
32
31
|
/**
|
|
@@ -36,7 +35,7 @@ export const useRookAndroidBackgroundSteps = () => {
|
|
|
36
35
|
const enableBackgroundAndroidSteps = async () => {
|
|
37
36
|
isRunningOnAndroid();
|
|
38
37
|
isModuleReady(ready);
|
|
39
|
-
return
|
|
38
|
+
return RookSdk.enableBackgroundAndroidSteps();
|
|
40
39
|
};
|
|
41
40
|
|
|
42
41
|
/**
|
|
@@ -46,7 +45,7 @@ export const useRookAndroidBackgroundSteps = () => {
|
|
|
46
45
|
const disableBackgroundAndroidSteps = () => {
|
|
47
46
|
isRunningOnAndroid();
|
|
48
47
|
isModuleReady(ready);
|
|
49
|
-
return
|
|
48
|
+
return RookSdk.disableBackgroundAndroidSteps();
|
|
50
49
|
};
|
|
51
50
|
|
|
52
51
|
/**
|
|
@@ -57,7 +56,7 @@ export const useRookAndroidBackgroundSteps = () => {
|
|
|
57
56
|
const isBackgroundAndroidStepsActive = () => {
|
|
58
57
|
isRunningOnAndroid();
|
|
59
58
|
isModuleReady(ready);
|
|
60
|
-
return
|
|
59
|
+
return RookSdk.isBackgroundAndroidStepsActive();
|
|
61
60
|
};
|
|
62
61
|
|
|
63
62
|
/**
|
|
@@ -67,18 +66,7 @@ export const useRookAndroidBackgroundSteps = () => {
|
|
|
67
66
|
const syncTodayAndroidStepsCount = () => {
|
|
68
67
|
isRunningOnAndroid();
|
|
69
68
|
isModuleReady(ready);
|
|
70
|
-
return
|
|
71
|
-
};
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
* The function `syncTodayHealthConnectStepsCount` retrieves the number of steps taken today asynchronously as string.
|
|
75
|
-
* @returns The function `syncTodayHealthConnectStepsCount` is returning the result of calling
|
|
76
|
-
*/
|
|
77
|
-
const syncTodayHealthConnectStepsCount = () => {
|
|
78
|
-
const currentModule = getNativeModule(nativeModules.android.SYNC);
|
|
79
|
-
isRunningOnAndroid();
|
|
80
|
-
isModuleReady(ready);
|
|
81
|
-
return currentModule.syncTodayHealthConnectStepsCount();
|
|
69
|
+
return RookSdk.syncTodayAndroidStepsCount();
|
|
82
70
|
};
|
|
83
71
|
return {
|
|
84
72
|
ready,
|
|
@@ -86,8 +74,7 @@ export const useRookAndroidBackgroundSteps = () => {
|
|
|
86
74
|
enableBackgroundAndroidSteps,
|
|
87
75
|
disableBackgroundAndroidSteps,
|
|
88
76
|
isBackgroundAndroidStepsActive,
|
|
89
|
-
syncTodayAndroidStepsCount
|
|
90
|
-
syncTodayHealthConnectStepsCount
|
|
77
|
+
syncTodayAndroidStepsCount
|
|
91
78
|
};
|
|
92
79
|
};
|
|
93
80
|
//# sourceMappingURL=useRookAndroidBackgroundSteps.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["RookSdk","useRookSyncGateContext","isModuleReady","isRunningOnAndroid","useRookAndroidBackgroundSteps","state","ready","isStepsAvailable","enableBackgroundAndroidSteps","disableBackgroundAndroidSteps","isBackgroundAndroidStepsActive","syncTodayAndroidStepsCount"],"sourceRoot":"../../../src","sources":["hooks/useRookAndroidBackgroundSteps.ts"],"mappings":";;AAAA,OAAOA,OAAO,MAAM,qBAAkB;AACtC,SAASC,sBAAsB,QAAQ,mCAAgC;AACvE,SAASC,aAAa,QAAQ,2BAAwB;AACtD,OAAOC,kBAAkB,MAAM,gCAA6B;;AAE5D;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,6BAA6B,GAAGA,CAAA,KAAM;EACjD,MAAM;IACJC,KAAK,EAAE;MAAEC;IAAM;EACjB,CAAC,GAAGL,sBAAsB,CAAC,CAAC;;EAE5B;AACF;AACA;AACA;EACE,MAAMM,gBAAgB,GAAG,MAAAA,CAAA,KAA8B;IACrDJ,kBAAkB,CAAC,CAAC;IACpBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACO,gBAAgB,CAAC,CAAC;EACnC,CAAC;;EAED;AACF;AACA;AACA;EACE,MAAMC,4BAA4B,GAAG,MAAAA,CAAA,KAA8B;IACjEL,kBAAkB,CAAC,CAAC;IACpBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACQ,4BAA4B,CAAC,CAAC;EAC/C,CAAC;;EAED;AACF;AACA;AACA;EACE,MAAMC,6BAA6B,GAAGA,CAAA,KAAwB;IAC5DN,kBAAkB,CAAC,CAAC;IACpBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACS,6BAA6B,CAAC,CAAC;EAChD,CAAC;;EAED;AACF;AACA;AACA;AACA;EACE,MAAMC,8BAA8B,GAAGA,CAAA,KAAwB;IAC7DP,kBAAkB,CAAC,CAAC;IACpBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACU,8BAA8B,CAAC,CAAC;EACjD,CAAC;;EAED;AACF;AACA;AACA;EACE,MAAMC,0BAA0B,GAAGA,CAAA,KAAuB;IACxDR,kBAAkB,CAAC,CAAC;IACpBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACW,0BAA0B,CAAC,CAAC;EAC7C,CAAC;EAED,OAAO;IACLL,KAAK;IACLC,gBAAgB;IAChBC,4BAA4B;IAC5BC,6BAA6B;IAC7BC,8BAA8B;IAC9BC;EACF,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import RookSdk from "../NativeRookSdk.js";
|
|
4
|
+
import { useRookSyncGateContext } from "../context/RookSyncGateContext.js";
|
|
5
|
+
import { isModuleReady } from "../utils/isModuleReady.js";
|
|
6
|
+
import { isRunningOniOS } from "../utils/isRunningOniOS.js";
|
|
7
7
|
export const useRookAppleHealth = () => {
|
|
8
|
-
const rookSync = useRef(getNativeModule(nativeModules.ios.BACKGROUND));
|
|
9
8
|
const {
|
|
10
9
|
state: {
|
|
11
10
|
ready
|
|
@@ -21,7 +20,7 @@ export const useRookAppleHealth = () => {
|
|
|
21
20
|
const enableBackGroundUpdates = () => {
|
|
22
21
|
isRunningOniOS();
|
|
23
22
|
isModuleReady(ready);
|
|
24
|
-
return
|
|
23
|
+
return RookSdk.enableBackGroundUpdates();
|
|
25
24
|
};
|
|
26
25
|
|
|
27
26
|
/**
|
|
@@ -33,34 +32,23 @@ export const useRookAppleHealth = () => {
|
|
|
33
32
|
const disableBackGroundUpdates = () => {
|
|
34
33
|
isRunningOniOS();
|
|
35
34
|
isModuleReady(ready);
|
|
36
|
-
return
|
|
35
|
+
return RookSdk.disableBackGroundUpdates();
|
|
37
36
|
};
|
|
38
37
|
|
|
39
38
|
/**
|
|
40
39
|
* This function checks if background summaries are enabled.
|
|
41
40
|
* @returns The function `isBackGroundForSummariesEnable` is returning a boolean value
|
|
42
41
|
*/
|
|
43
|
-
const
|
|
44
|
-
isRunningOniOS();
|
|
45
|
-
isModuleReady(ready);
|
|
46
|
-
return rookSync.current.isBackGroundForSummariesEnable();
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* This function checks if background events are enabled.
|
|
51
|
-
* @returns The function `isBackGroundForEventsEnable` is returning a boolean value
|
|
52
|
-
*/
|
|
53
|
-
const isBackGroundForEventsEnable = async () => {
|
|
42
|
+
const isBackgroundUpdatesEnabled = async () => {
|
|
54
43
|
isRunningOniOS();
|
|
55
44
|
isModuleReady(ready);
|
|
56
|
-
return
|
|
45
|
+
return RookSdk.isBackgroundUpdatesEnabled();
|
|
57
46
|
};
|
|
58
47
|
return {
|
|
59
48
|
ready,
|
|
60
49
|
enableBackGroundUpdates,
|
|
61
50
|
disableBackGroundUpdates,
|
|
62
|
-
|
|
63
|
-
isBackGroundForSummariesEnable
|
|
51
|
+
isBackgroundUpdatesEnabled
|
|
64
52
|
};
|
|
65
53
|
};
|
|
66
54
|
//# sourceMappingURL=useRookAppleHealth.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["RookSdk","useRookSyncGateContext","isModuleReady","isRunningOniOS","useRookAppleHealth","state","ready","enableBackGroundUpdates","disableBackGroundUpdates","isBackgroundUpdatesEnabled"],"sourceRoot":"../../../src","sources":["hooks/useRookAppleHealth.ts"],"mappings":";;AAAA,OAAOA,OAAO,MAAM,qBAAkB;AAEtC,SAASC,sBAAsB,QAAQ,mCAAgC;AACvE,SAASC,aAAa,QAAQ,2BAAwB;AACtD,SAASC,cAAc,QAAQ,4BAAyB;AAExD,OAAO,MAAMC,kBAAkB,GAAGA,CAAA,KAAM;EACtC,MAAM;IACJC,KAAK,EAAE;MAAEC;IAAM;EACjB,CAAC,GAAGL,sBAAsB,CAAC,CAAC;;EAE5B;AACF;AACA;AACA;AACA;AACA;EACE,MAAMM,uBAAuB,GAAGA,CAAA,KAAwB;IACtDJ,cAAc,CAAC,CAAC;IAChBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACO,uBAAuB,CAAC,CAAC;EAC1C,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;EACE,MAAMC,wBAAwB,GAAGA,CAAA,KAAwB;IACvDL,cAAc,CAAC,CAAC;IAChBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACQ,wBAAwB,CAAC,CAAC;EAC3C,CAAC;;EAED;AACF;AACA;AACA;EACE,MAAMC,0BAA0B,GAAG,MAAAA,CAAA,KAA8B;IAC/DN,cAAc,CAAC,CAAC;IAChBD,aAAa,CAACI,KAAK,CAAC;IAEpB,OAAON,OAAO,CAACS,0BAA0B,CAAC,CAAC;EAC7C,CAAC;EAED,OAAO;IACLH,KAAK;IACLC,uBAAuB;IACvBC,wBAAwB;IACxBC;EACF,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import { isModuleReady } from
|
|
6
|
-
import isRunningOnAndroid from '../utils/isRunningOnAndroid';
|
|
7
|
-
import { isRunningOniOS } from '../utils/isRunningOniOS';
|
|
8
|
-
import nativeModules from '../utils/nativeModules';
|
|
9
|
-
import { packageInfo } from '../utils/packageInfo';
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import RookSdk from "../NativeRookSdk.js";
|
|
4
|
+
import { useRookSyncGateContext } from "../context/RookSyncGateContext.js";
|
|
5
|
+
import { isModuleReady } from "../utils/isModuleReady.js";
|
|
10
6
|
/**
|
|
11
7
|
* The `useRookConfiguration` hook provides various asynchronous methods for managing the configuration
|
|
12
8
|
* of the ROOK SDK
|
|
@@ -14,10 +10,6 @@ import { packageInfo } from '../utils/packageInfo';
|
|
|
14
10
|
* the SDK
|
|
15
11
|
*/
|
|
16
12
|
export const useRookConfiguration = () => {
|
|
17
|
-
const rookSync = useRef(getNativeModule(Platform.select({
|
|
18
|
-
android: () => nativeModules.android.CONFIGURATION,
|
|
19
|
-
default: () => nativeModules.ios.CONFIGURATION
|
|
20
|
-
})()));
|
|
21
13
|
const {
|
|
22
14
|
state: {
|
|
23
15
|
ready
|
|
@@ -31,7 +23,7 @@ export const useRookConfiguration = () => {
|
|
|
31
23
|
*/
|
|
32
24
|
const getUserID = async () => {
|
|
33
25
|
isModuleReady(ready);
|
|
34
|
-
const result = await
|
|
26
|
+
const result = await RookSdk.getUserID();
|
|
35
27
|
if (result) dispatch({
|
|
36
28
|
type: 'SET_USER_ID',
|
|
37
29
|
userID: result
|
|
@@ -48,7 +40,7 @@ export const useRookConfiguration = () => {
|
|
|
48
40
|
*/
|
|
49
41
|
const updateUserID = async userID => {
|
|
50
42
|
isModuleReady(ready);
|
|
51
|
-
const result = await
|
|
43
|
+
const result = await RookSdk.updateUserID(userID);
|
|
52
44
|
dispatch({
|
|
53
45
|
type: 'SET_USER_ID',
|
|
54
46
|
userID
|
|
@@ -56,27 +48,13 @@ export const useRookConfiguration = () => {
|
|
|
56
48
|
return result;
|
|
57
49
|
};
|
|
58
50
|
|
|
59
|
-
/**
|
|
60
|
-
* The function `clearUserID` clears the user ID and returns a boolean indicating success.
|
|
61
|
-
* @returns The `clearUserID` function is returning a Promise that resolves to a boolean value.
|
|
62
|
-
*/
|
|
63
|
-
const clearUserID = async sources => {
|
|
64
|
-
isModuleReady(ready);
|
|
65
|
-
dispatch({
|
|
66
|
-
type: 'SET_USER_ID',
|
|
67
|
-
userID: ''
|
|
68
|
-
});
|
|
69
|
-
if (!packageInfo.isAndroid) return rookSync.current.clearUserID();
|
|
70
|
-
return rookSync.current.clearUserID(sources);
|
|
71
|
-
};
|
|
72
|
-
|
|
73
51
|
/**
|
|
74
52
|
* This function `syncUserTimeZone` synchronizes the user's time zone using
|
|
75
53
|
* @returns The `syncUserTimeZone` function returns a boolean value, indicating success or failure
|
|
76
54
|
*/
|
|
77
55
|
const syncUserTimeZone = async () => {
|
|
78
56
|
isModuleReady(ready);
|
|
79
|
-
const result = await
|
|
57
|
+
const result = await RookSdk.syncUserTimeZone();
|
|
80
58
|
return result;
|
|
81
59
|
};
|
|
82
60
|
|
|
@@ -90,91 +68,14 @@ export const useRookConfiguration = () => {
|
|
|
90
68
|
type: 'SET_USER_ID',
|
|
91
69
|
userID: ''
|
|
92
70
|
});
|
|
93
|
-
|
|
94
|
-
return rookSync.current.removeUserFromRook(sources);
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* This method enables the automatic upload of the summaries from the previous day of the current device's date. Every time the user opens the app it will try to upload the summaries, before use this method is necessary to add a user id and request permissions.
|
|
99
|
-
* @returns The function `enableAppleHealthSync` is returning a boolean value, which is the result
|
|
100
|
-
* of enable the Apple Health
|
|
101
|
-
*/
|
|
102
|
-
const enableAppleHealthSync = async () => {
|
|
103
|
-
isRunningOniOS();
|
|
104
|
-
isModuleReady(ready);
|
|
105
|
-
const result = await rookSync.current.enableSync();
|
|
106
|
-
return result;
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* This method disables the automatic upload of the summaries from the previous day of the current device's date.
|
|
111
|
-
* @returns The function `disableAppleHealthSync` is returning a boolean value, which is the result
|
|
112
|
-
* of disabling the Apple Health
|
|
113
|
-
*/
|
|
114
|
-
const disableAppleHealthSync = async () => {
|
|
115
|
-
isRunningOniOS();
|
|
116
|
-
isModuleReady(ready);
|
|
117
|
-
const result = await rookSync.current.disableSync();
|
|
118
|
-
return result;
|
|
119
|
-
};
|
|
120
|
-
|
|
121
|
-
/**
|
|
122
|
-
* The function `isAppleHealthSyncEnabled` checks if Apple Health sync is enabled and returns a
|
|
123
|
-
* boolean value.
|
|
124
|
-
* @returns The function `isAppleHealthSyncEnabled` is returning the a boolean value indicating if is enable or not
|
|
125
|
-
*/
|
|
126
|
-
const isAppleHealthSyncEnabled = async () => {
|
|
127
|
-
isRunningOniOS();
|
|
128
|
-
isModuleReady(ready);
|
|
129
|
-
const result = await rookSync.current.isSyncEnable();
|
|
130
|
-
return result;
|
|
131
|
-
};
|
|
132
|
-
|
|
133
|
-
/**
|
|
134
|
-
* This function is intend to support background sync for android 14 and previous
|
|
135
|
-
* The function `scheduleYesterdaySync` is an asynchronous function that syncs data of the different summaries
|
|
136
|
-
* and events that Rook has
|
|
137
|
-
* @returns The `scheduleYesterdaySync` function is returning a Promise that resolves to a boolean
|
|
138
|
-
* value.
|
|
139
|
-
*/
|
|
140
|
-
const scheduleAndroidYesterdaySync = async () => {
|
|
141
|
-
const syncModule = getNativeModule(nativeModules.android.SYNC);
|
|
142
|
-
isRunningOnAndroid();
|
|
143
|
-
isModuleReady(ready);
|
|
144
|
-
return syncModule.scheduleYesterdaySync();
|
|
145
|
-
};
|
|
146
|
-
const enableSamsungSync = async () => {
|
|
147
|
-
const syncModule = getNativeModule(nativeModules.android.SYNC);
|
|
148
|
-
isRunningOnAndroid();
|
|
149
|
-
isModuleReady(ready);
|
|
150
|
-
return syncModule.enableSamsungSync();
|
|
151
|
-
};
|
|
152
|
-
const isSamsungSyncEnabled = async () => {
|
|
153
|
-
const syncModule = getNativeModule(nativeModules.android.SYNC);
|
|
154
|
-
isRunningOnAndroid();
|
|
155
|
-
isModuleReady(ready);
|
|
156
|
-
return syncModule.isSamsungSyncEnabled();
|
|
157
|
-
};
|
|
158
|
-
const disableSamsungSync = async () => {
|
|
159
|
-
const syncModule = getNativeModule(nativeModules.android.SYNC);
|
|
160
|
-
isRunningOnAndroid();
|
|
161
|
-
isModuleReady(ready);
|
|
162
|
-
return syncModule.disableSamsungSync();
|
|
71
|
+
return RookSdk.removeUserFromRook(sources);
|
|
163
72
|
};
|
|
164
73
|
return {
|
|
165
74
|
ready,
|
|
166
|
-
clearUserID,
|
|
167
|
-
disableAppleHealthSync,
|
|
168
|
-
enableAppleHealthSync,
|
|
169
|
-
isAppleHealthSyncEnabled,
|
|
170
75
|
getUserID,
|
|
171
76
|
updateUserID,
|
|
172
77
|
removeUserFromRook,
|
|
173
|
-
syncUserTimeZone
|
|
174
|
-
scheduleAndroidYesterdaySync,
|
|
175
|
-
enableSamsungSync,
|
|
176
|
-
isSamsungSyncEnabled,
|
|
177
|
-
disableSamsungSync
|
|
78
|
+
syncUserTimeZone
|
|
178
79
|
};
|
|
179
80
|
};
|
|
180
81
|
//# sourceMappingURL=useRookConfiguration.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["RookSdk","useRookSyncGateContext","isModuleReady","useRookConfiguration","state","ready","dispatch","getUserID","result","type","userID","updateUserID","syncUserTimeZone","removeUserFromRook","sources"],"sourceRoot":"../../../src","sources":["hooks/useRookConfiguration.ts"],"mappings":";;AAAA,OAAOA,OAAO,MAAM,qBAAkB;AAEtC,SAASC,sBAAsB,QAAQ,mCAAgC;AACvE,SAASC,aAAa,QAAQ,2BAAwB;AAGtD;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,oBAAoB,GAAGA,CAAA,KAAM;EACxC,MAAM;IACJC,KAAK,EAAE;MAAEC;IAAM,CAAC;IAChBC;EACF,CAAC,GAAGL,sBAAsB,CAAC,CAAC;;EAE5B;AACF;AACA;AACA;EACE,MAAMM,SAAS,GAAG,MAAAA,CAAA,KAA6B;IAC7CL,aAAa,CAACG,KAAK,CAAC;IAEpB,MAAMG,MAAM,GAAG,MAAMR,OAAO,CAACO,SAAS,CAAC,CAAC;IAExC,IAAIC,MAAM,EAAEF,QAAQ,CAAC;MAAEG,IAAI,EAAE,aAAa;MAAEC,MAAM,EAAEF;IAAO,CAAC,CAAC;IAE7D,OAAOA,MAAM;EACf,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;EACE,MAAMG,YAAY,GAAG,MAAOD,MAAc,IAAuB;IAC/DR,aAAa,CAACG,KAAK,CAAC;IAEpB,MAAMG,MAAe,GAAG,MAAMR,OAAO,CAACW,YAAY,CAACD,MAAM,CAAC;IAE1DJ,QAAQ,CAAC;MAAEG,IAAI,EAAE,aAAa;MAAEC;IAAO,CAAC,CAAC;IAEzC,OAAOF,MAAM;EACf,CAAC;;EAED;AACF;AACA;AACA;EACE,MAAMI,gBAAgB,GAAG,MAAAA,CAAA,KAA8B;IACrDV,aAAa,CAACG,KAAK,CAAC;IAEpB,MAAMG,MAAe,GAAG,MAAMR,OAAO,CAACY,gBAAgB,CAAC,CAAC;IACxD,OAAOJ,MAAM;EACf,CAAC;;EAED;AACF;AACA;AACA;EACE,MAAMK,kBAAkB,GAAG,MACzBC,OAAwB,IACH;IACrBZ,aAAa,CAACG,KAAK,CAAC;IAEpBC,QAAQ,CAAC;MAAEG,IAAI,EAAE,aAAa;MAAEC,MAAM,EAAE;IAAG,CAAC,CAAC;IAE7C,OAAOV,OAAO,CAACa,kBAAkB,CAACC,OAAO,CAAC;EAC5C,CAAC;EAED,OAAO;IACLT,KAAK;IACLE,SAAS;IACTI,YAAY;IACZE,kBAAkB;IAClBD;EACF,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,17 +1,12 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import RookSdk from "../NativeRookSdk.js";
|
|
2
4
|
import { Platform } from 'react-native';
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import
|
|
7
|
-
import { useRookSyncGateContext } from '../context/RookSyncGateContext';
|
|
8
|
-
import { SDKDataSource } from '../types/SDKSources';
|
|
9
|
-
import { packageInfo } from '../utils/packageInfo';
|
|
5
|
+
import { isModuleReady } from "../utils/isModuleReady.js";
|
|
6
|
+
import { isValidDate } from "../utils/isValidDate.js";
|
|
7
|
+
import { useRookSyncGateContext } from "../context/RookSyncGateContext.js";
|
|
8
|
+
import { SDKDataSource } from "../types/SDKSources.js";
|
|
10
9
|
export const useRookData = () => {
|
|
11
|
-
const rookData = useRef(getNativeModule(Platform.select({
|
|
12
|
-
android: () => nativeModules.android.LOCAL_DATA,
|
|
13
|
-
default: () => nativeModules.ios.LOCAL_DATA
|
|
14
|
-
})()));
|
|
15
10
|
const {
|
|
16
11
|
state: {
|
|
17
12
|
ready
|
|
@@ -23,15 +18,15 @@ export const useRookData = () => {
|
|
|
23
18
|
}) => {
|
|
24
19
|
isModuleReady(ready);
|
|
25
20
|
isValidDate(date);
|
|
26
|
-
if (
|
|
27
|
-
const result = await
|
|
21
|
+
if (Platform.OS === 'android' && source === SDKDataSource.SAMSUNG_HEALTH) {
|
|
22
|
+
const result = await RookSdk.getSamsungSleepSummary(date);
|
|
28
23
|
return JSON.parse(result);
|
|
29
24
|
}
|
|
30
|
-
if (
|
|
31
|
-
const result = await
|
|
25
|
+
if (Platform.OS === 'android' && source === SDKDataSource.HEALTH_CONNECT) {
|
|
26
|
+
const result = await RookSdk.getHealthConnectSleepSummary(date);
|
|
32
27
|
return JSON.parse(result);
|
|
33
28
|
}
|
|
34
|
-
return
|
|
29
|
+
return RookSdk.getAppleHealthSleepSummary(date);
|
|
35
30
|
};
|
|
36
31
|
const getPhysicalSummary = async ({
|
|
37
32
|
date,
|
|
@@ -39,15 +34,15 @@ export const useRookData = () => {
|
|
|
39
34
|
}) => {
|
|
40
35
|
isModuleReady(ready);
|
|
41
36
|
isValidDate(date);
|
|
42
|
-
if (
|
|
43
|
-
const result = await
|
|
37
|
+
if (Platform.OS === 'android' && source === SDKDataSource.SAMSUNG_HEALTH) {
|
|
38
|
+
const result = await RookSdk.getSamsungPhysicalSummary(date);
|
|
44
39
|
return JSON.parse(result);
|
|
45
40
|
}
|
|
46
|
-
if (
|
|
47
|
-
const result = await
|
|
41
|
+
if (Platform.OS === 'android' && source === SDKDataSource.HEALTH_CONNECT) {
|
|
42
|
+
const result = await RookSdk.getHealthConnectPhysicalSummary(date);
|
|
48
43
|
return JSON.parse(result);
|
|
49
44
|
}
|
|
50
|
-
return
|
|
45
|
+
return RookSdk.getAppleHealthPhysicalSummary(date);
|
|
51
46
|
};
|
|
52
47
|
const getBodySummary = async ({
|
|
53
48
|
date,
|
|
@@ -55,15 +50,15 @@ export const useRookData = () => {
|
|
|
55
50
|
}) => {
|
|
56
51
|
isModuleReady(ready);
|
|
57
52
|
isValidDate(date);
|
|
58
|
-
if (
|
|
59
|
-
const result = await
|
|
53
|
+
if (Platform.OS === 'android' && source === SDKDataSource.SAMSUNG_HEALTH) {
|
|
54
|
+
const result = await RookSdk.getSamsungBodySummary(date);
|
|
60
55
|
return JSON.parse(result);
|
|
61
56
|
}
|
|
62
|
-
if (
|
|
63
|
-
const result = await
|
|
57
|
+
if (Platform.OS === 'android' && source === SDKDataSource.HEALTH_CONNECT) {
|
|
58
|
+
const result = await RookSdk.getHealthConnectBodySummary(date);
|
|
64
59
|
return JSON.parse(result);
|
|
65
60
|
}
|
|
66
|
-
return
|
|
61
|
+
return RookSdk.getAppleHealthBodySummary(date);
|
|
67
62
|
};
|
|
68
63
|
const getActivityEvents = async ({
|
|
69
64
|
date,
|
|
@@ -71,22 +66,29 @@ export const useRookData = () => {
|
|
|
71
66
|
}) => {
|
|
72
67
|
isModuleReady(ready);
|
|
73
68
|
isValidDate(date);
|
|
74
|
-
if (
|
|
75
|
-
const result = await
|
|
69
|
+
if (Platform.OS === 'android' && source === SDKDataSource.SAMSUNG_HEALTH) {
|
|
70
|
+
const result = await RookSdk.getSamsungActivityEvents(date);
|
|
76
71
|
return JSON.parse(result);
|
|
77
72
|
}
|
|
78
|
-
if (
|
|
79
|
-
const result = await
|
|
73
|
+
if (Platform.OS === 'android' && source === SDKDataSource.HEALTH_CONNECT) {
|
|
74
|
+
const result = await RookSdk.getHealthConnectActivityEvents(date);
|
|
80
75
|
return JSON.parse(result);
|
|
81
76
|
}
|
|
82
|
-
return
|
|
77
|
+
return RookSdk.getAppleHealthActivityEvents(date);
|
|
78
|
+
};
|
|
79
|
+
const getTodayHeartRate = async source => {
|
|
80
|
+
if (Platform.OS !== 'android' && source === SDKDataSource.APPLE_HEALTH) {
|
|
81
|
+
return RookSdk.getTodayHeartRate();
|
|
82
|
+
}
|
|
83
|
+
throw new Error('Please check the data source');
|
|
83
84
|
};
|
|
84
85
|
return {
|
|
85
86
|
ready,
|
|
86
87
|
getSleepSummary,
|
|
87
88
|
getPhysicalSummary,
|
|
88
89
|
getBodySummary,
|
|
89
|
-
getActivityEvents
|
|
90
|
+
getActivityEvents,
|
|
91
|
+
getTodayHeartRate
|
|
90
92
|
};
|
|
91
93
|
};
|
|
92
94
|
//# sourceMappingURL=useRookData.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["RookSdk","Platform","isModuleReady","isValidDate","useRookSyncGateContext","SDKDataSource","useRookData","state","ready","getSleepSummary","date","source","OS","SAMSUNG_HEALTH","result","getSamsungSleepSummary","JSON","parse","HEALTH_CONNECT","getHealthConnectSleepSummary","getAppleHealthSleepSummary","getPhysicalSummary","getSamsungPhysicalSummary","getHealthConnectPhysicalSummary","getAppleHealthPhysicalSummary","getBodySummary","getSamsungBodySummary","getHealthConnectBodySummary","getAppleHealthBodySummary","getActivityEvents","getSamsungActivityEvents","getHealthConnectActivityEvents","getAppleHealthActivityEvents","getTodayHeartRate","APPLE_HEALTH","Error"],"sourceRoot":"../../../src","sources":["hooks/useRookData.ts"],"mappings":"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","ignoreList":[]}
|