@kingstinct/react-native-healthkit 4.4.5 → 5.1.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.
Files changed (240) hide show
  1. package/README.md +1 -1
  2. package/ios/ReactNativeHealthkit.m +6 -0
  3. package/ios/ReactNativeHealthkit.swift +23 -0
  4. package/ios/ReactNativeHealthkit.xcodeproj/project.xcworkspace/xcuserdata/robertherber.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
  5. package/lib/commonjs/hooks/useHealthkitAuthorization.js +41 -0
  6. package/lib/commonjs/hooks/useHealthkitAuthorization.js.map +1 -0
  7. package/lib/commonjs/hooks/useIsHealthDataAvailable.js +29 -0
  8. package/lib/commonjs/hooks/useIsHealthDataAvailable.js.map +1 -0
  9. package/lib/commonjs/hooks/useMostRecentCategorySample.js +27 -0
  10. package/lib/commonjs/hooks/useMostRecentCategorySample.js.map +1 -0
  11. package/lib/commonjs/hooks/useMostRecentQuantitySample.js +43 -0
  12. package/lib/commonjs/hooks/useMostRecentQuantitySample.js.map +1 -0
  13. package/lib/commonjs/hooks/useMostRecentWorkout.js +60 -0
  14. package/lib/commonjs/hooks/useMostRecentWorkout.js.map +1 -0
  15. package/lib/commonjs/hooks/useStatisticsForQuantity.js +35 -0
  16. package/lib/commonjs/hooks/useStatisticsForQuantity.js.map +1 -0
  17. package/lib/commonjs/hooks/useSubscribeToChanges.js +37 -0
  18. package/lib/commonjs/hooks/useSubscribeToChanges.js.map +1 -0
  19. package/lib/commonjs/index.ios.js +69 -393
  20. package/lib/commonjs/index.ios.js.map +1 -1
  21. package/lib/commonjs/index.js +3 -15
  22. package/lib/commonjs/index.js.map +1 -1
  23. package/lib/commonjs/native-types.js +249 -78
  24. package/lib/commonjs/native-types.js.map +1 -1
  25. package/lib/commonjs/types.js +13 -0
  26. package/lib/commonjs/types.js.map +1 -1
  27. package/lib/commonjs/utils/deleteQuantitySample.js +16 -0
  28. package/lib/commonjs/utils/deleteQuantitySample.js.map +1 -0
  29. package/lib/commonjs/utils/deserializeCategorySample.js +15 -0
  30. package/lib/commonjs/utils/deserializeCategorySample.js.map +1 -0
  31. package/lib/commonjs/utils/deserializeCorrelation.js +32 -0
  32. package/lib/commonjs/utils/deserializeCorrelation.js.map +1 -0
  33. package/lib/commonjs/utils/deserializeSample.js +17 -0
  34. package/lib/commonjs/utils/deserializeSample.js.map +1 -0
  35. package/lib/commonjs/utils/deserializeWorkout.js +17 -0
  36. package/lib/commonjs/utils/deserializeWorkout.js.map +1 -0
  37. package/lib/commonjs/utils/ensureMetadata.js +14 -0
  38. package/lib/commonjs/utils/ensureMetadata.js.map +1 -0
  39. package/lib/commonjs/utils/ensureUnit.js +23 -0
  40. package/lib/commonjs/utils/ensureUnit.js.map +1 -0
  41. package/lib/commonjs/utils/getDateOfBirth.js +19 -0
  42. package/lib/commonjs/utils/getDateOfBirth.js.map +1 -0
  43. package/lib/commonjs/utils/getMostRecentCategorySample.js +22 -0
  44. package/lib/commonjs/utils/getMostRecentCategorySample.js.map +1 -0
  45. package/lib/commonjs/utils/getMostRecentQuantitySample.js +22 -0
  46. package/lib/commonjs/utils/getMostRecentQuantitySample.js.map +1 -0
  47. package/lib/commonjs/utils/getMostRecentWorkout.js +24 -0
  48. package/lib/commonjs/utils/getMostRecentWorkout.js.map +1 -0
  49. package/lib/commonjs/utils/getPreferredUnit.js +19 -0
  50. package/lib/commonjs/utils/getPreferredUnit.js.map +1 -0
  51. package/lib/commonjs/utils/getPreferredUnits.js +19 -0
  52. package/lib/commonjs/utils/getPreferredUnits.js.map +1 -0
  53. package/lib/commonjs/utils/getPreferredUnitsTyped.js +46 -0
  54. package/lib/commonjs/utils/getPreferredUnitsTyped.js.map +1 -0
  55. package/lib/commonjs/utils/getRequestStatusForAuthorization.js +25 -0
  56. package/lib/commonjs/utils/getRequestStatusForAuthorization.js.map +1 -0
  57. package/lib/commonjs/utils/prepareOptions.js +27 -0
  58. package/lib/commonjs/utils/prepareOptions.js.map +1 -0
  59. package/lib/commonjs/utils/queryCategorySamples.js +24 -0
  60. package/lib/commonjs/utils/queryCategorySamples.js.map +1 -0
  61. package/lib/commonjs/utils/queryCorrelationSamples.js +24 -0
  62. package/lib/commonjs/utils/queryCorrelationSamples.js.map +1 -0
  63. package/lib/commonjs/utils/queryQuantitySamples.js +27 -0
  64. package/lib/commonjs/utils/queryQuantitySamples.js.map +1 -0
  65. package/lib/commonjs/utils/queryStatisticsForQuantity.js +34 -0
  66. package/lib/commonjs/utils/queryStatisticsForQuantity.js.map +1 -0
  67. package/lib/commonjs/utils/queryWorkouts.js +30 -0
  68. package/lib/commonjs/utils/queryWorkouts.js.map +1 -0
  69. package/lib/commonjs/utils/requestAuthorization.js +25 -0
  70. package/lib/commonjs/utils/requestAuthorization.js.map +1 -0
  71. package/lib/commonjs/utils/saveCategorySample.js +21 -0
  72. package/lib/commonjs/utils/saveCategorySample.js.map +1 -0
  73. package/lib/commonjs/utils/saveCorrelationSample.js +24 -0
  74. package/lib/commonjs/utils/saveCorrelationSample.js.map +1 -0
  75. package/lib/commonjs/utils/saveQuantitySample.js +21 -0
  76. package/lib/commonjs/utils/saveQuantitySample.js.map +1 -0
  77. package/lib/commonjs/utils/saveWorkoutSample.js +25 -0
  78. package/lib/commonjs/utils/saveWorkoutSample.js.map +1 -0
  79. package/lib/commonjs/utils/serializeDate.js +12 -0
  80. package/lib/commonjs/utils/serializeDate.js.map +1 -0
  81. package/lib/commonjs/utils/subscribeToChanges.js +37 -0
  82. package/lib/commonjs/utils/subscribeToChanges.js.map +1 -0
  83. package/lib/module/hooks/useHealthkitAuthorization.js +29 -0
  84. package/lib/module/hooks/useHealthkitAuthorization.js.map +1 -0
  85. package/lib/module/hooks/useIsHealthDataAvailable.js +18 -0
  86. package/lib/module/hooks/useIsHealthDataAvailable.js.map +1 -0
  87. package/lib/module/hooks/useMostRecentCategorySample.js +15 -0
  88. package/lib/module/hooks/useMostRecentCategorySample.js.map +1 -0
  89. package/lib/module/hooks/useMostRecentQuantitySample.js +30 -0
  90. package/lib/module/hooks/useMostRecentQuantitySample.js.map +1 -0
  91. package/lib/module/hooks/useMostRecentWorkout.js +47 -0
  92. package/lib/module/hooks/useMostRecentWorkout.js.map +1 -0
  93. package/lib/module/hooks/useStatisticsForQuantity.js +23 -0
  94. package/lib/module/hooks/useStatisticsForQuantity.js.map +1 -0
  95. package/lib/module/hooks/useSubscribeToChanges.js +26 -0
  96. package/lib/module/hooks/useSubscribeToChanges.js.map +1 -0
  97. package/lib/module/index.ios.js +35 -370
  98. package/lib/module/index.ios.js.map +1 -1
  99. package/lib/module/index.js +4 -5
  100. package/lib/module/index.js.map +1 -1
  101. package/lib/module/native-types.js +232 -74
  102. package/lib/module/native-types.js.map +1 -1
  103. package/lib/module/types.js +15 -0
  104. package/lib/module/types.js.map +1 -1
  105. package/lib/module/utils/deleteQuantitySample.js +6 -0
  106. package/lib/module/utils/deleteQuantitySample.js.map +1 -0
  107. package/lib/module/utils/deserializeCategorySample.js +7 -0
  108. package/lib/module/utils/deserializeCategorySample.js.map +1 -0
  109. package/lib/module/utils/deserializeCorrelation.js +21 -0
  110. package/lib/module/utils/deserializeCorrelation.js.map +1 -0
  111. package/lib/module/utils/deserializeSample.js +9 -0
  112. package/lib/module/utils/deserializeSample.js.map +1 -0
  113. package/lib/module/utils/deserializeWorkout.js +9 -0
  114. package/lib/module/utils/deserializeWorkout.js.map +1 -0
  115. package/lib/module/utils/ensureMetadata.js +6 -0
  116. package/lib/module/utils/ensureMetadata.js.map +1 -0
  117. package/lib/module/utils/ensureUnit.js +13 -0
  118. package/lib/module/utils/ensureUnit.js.map +1 -0
  119. package/lib/module/utils/getDateOfBirth.js +9 -0
  120. package/lib/module/utils/getDateOfBirth.js.map +1 -0
  121. package/lib/module/utils/getMostRecentCategorySample.js +12 -0
  122. package/lib/module/utils/getMostRecentCategorySample.js.map +1 -0
  123. package/lib/module/utils/getMostRecentQuantitySample.js +12 -0
  124. package/lib/module/utils/getMostRecentQuantitySample.js.map +1 -0
  125. package/lib/module/utils/getMostRecentWorkout.js +14 -0
  126. package/lib/module/utils/getMostRecentWorkout.js.map +1 -0
  127. package/lib/module/utils/getPreferredUnit.js +9 -0
  128. package/lib/module/utils/getPreferredUnit.js.map +1 -0
  129. package/lib/module/utils/getPreferredUnits.js +9 -0
  130. package/lib/module/utils/getPreferredUnits.js.map +1 -0
  131. package/lib/module/utils/getPreferredUnitsTyped.js +34 -0
  132. package/lib/module/utils/getPreferredUnitsTyped.js.map +1 -0
  133. package/lib/module/utils/getRequestStatusForAuthorization.js +15 -0
  134. package/lib/module/utils/getRequestStatusForAuthorization.js.map +1 -0
  135. package/lib/module/utils/prepareOptions.js +17 -0
  136. package/lib/module/utils/prepareOptions.js.map +1 -0
  137. package/lib/module/utils/queryCategorySamples.js +12 -0
  138. package/lib/module/utils/queryCategorySamples.js.map +1 -0
  139. package/lib/module/utils/queryCorrelationSamples.js +12 -0
  140. package/lib/module/utils/queryCorrelationSamples.js.map +1 -0
  141. package/lib/module/utils/queryQuantitySamples.js +14 -0
  142. package/lib/module/utils/queryQuantitySamples.js.map +1 -0
  143. package/lib/module/utils/queryStatisticsForQuantity.js +23 -0
  144. package/lib/module/utils/queryStatisticsForQuantity.js.map +1 -0
  145. package/lib/module/utils/queryWorkouts.js +17 -0
  146. package/lib/module/utils/queryWorkouts.js.map +1 -0
  147. package/lib/module/utils/requestAuthorization.js +15 -0
  148. package/lib/module/utils/requestAuthorization.js.map +1 -0
  149. package/lib/module/utils/saveCategorySample.js +11 -0
  150. package/lib/module/utils/saveCategorySample.js.map +1 -0
  151. package/lib/module/utils/saveCorrelationSample.js +13 -0
  152. package/lib/module/utils/saveCorrelationSample.js.map +1 -0
  153. package/lib/module/utils/saveQuantitySample.js +11 -0
  154. package/lib/module/utils/saveQuantitySample.js.map +1 -0
  155. package/lib/module/utils/saveWorkoutSample.js +14 -0
  156. package/lib/module/utils/saveWorkoutSample.js.map +1 -0
  157. package/lib/module/utils/serializeDate.js +4 -0
  158. package/lib/module/utils/serializeDate.js.map +1 -0
  159. package/lib/module/utils/subscribeToChanges.js +25 -0
  160. package/lib/module/utils/subscribeToChanges.js.map +1 -0
  161. package/lib/typescript/example-expo/App.d.ts +2 -0
  162. package/lib/typescript/src/hooks/useHealthkitAuthorization.d.ts +3 -0
  163. package/lib/typescript/src/hooks/useIsHealthDataAvailable.d.ts +2 -0
  164. package/lib/typescript/src/hooks/useMostRecentCategorySample.d.ts +4 -0
  165. package/lib/typescript/src/hooks/useMostRecentQuantitySample.d.ts +4 -0
  166. package/lib/typescript/src/hooks/useMostRecentWorkout.d.ts +7 -0
  167. package/lib/typescript/src/hooks/useStatisticsForQuantity.d.ts +4 -0
  168. package/lib/typescript/src/hooks/useSubscribeToChanges.d.ts +3 -0
  169. package/lib/typescript/src/index.d.ts +2 -3
  170. package/lib/typescript/src/index.ios.d.ts +49 -3
  171. package/lib/typescript/src/native-types.d.ts +236 -70
  172. package/lib/typescript/src/types.d.ts +14 -90
  173. package/lib/typescript/src/utils/deleteQuantitySample.d.ts +4 -0
  174. package/lib/typescript/src/utils/deserializeCategorySample.d.ts +4 -0
  175. package/lib/typescript/src/utils/deserializeCorrelation.d.ts +4 -0
  176. package/lib/typescript/src/utils/deserializeSample.d.ts +4 -0
  177. package/lib/typescript/src/utils/deserializeWorkout.d.ts +4 -0
  178. package/lib/typescript/src/utils/ensureMetadata.d.ts +2 -0
  179. package/lib/typescript/src/utils/ensureUnit.d.ts +3 -0
  180. package/lib/typescript/src/utils/getDateOfBirth.d.ts +2 -0
  181. package/lib/typescript/src/utils/getMostRecentCategorySample.d.ts +3 -0
  182. package/lib/typescript/src/utils/getMostRecentQuantitySample.d.ts +3 -0
  183. package/lib/typescript/src/utils/getMostRecentWorkout.d.ts +5 -0
  184. package/lib/typescript/src/utils/getPreferredUnit.d.ts +4 -0
  185. package/lib/typescript/src/utils/getPreferredUnits.d.ts +4 -0
  186. package/lib/typescript/src/utils/getPreferredUnitsTyped.d.ts +9 -0
  187. package/lib/typescript/src/utils/getRequestStatusForAuthorization.d.ts +3 -0
  188. package/lib/typescript/src/utils/prepareOptions.d.ts +8 -0
  189. package/lib/typescript/src/utils/queryCategorySamples.d.ts +5 -0
  190. package/lib/typescript/src/utils/queryCorrelationSamples.d.ts +5 -0
  191. package/lib/typescript/src/utils/queryQuantitySamples.d.ts +7 -0
  192. package/lib/typescript/src/utils/queryStatisticsForQuantity.d.ts +14 -0
  193. package/lib/typescript/src/utils/queryWorkouts.d.ts +4 -0
  194. package/lib/typescript/src/utils/requestAuthorization.d.ts +3 -0
  195. package/lib/typescript/src/utils/saveCategorySample.d.ts +7 -0
  196. package/lib/typescript/src/utils/saveCorrelationSample.d.ts +8 -0
  197. package/lib/typescript/src/utils/saveQuantitySample.d.ts +7 -0
  198. package/lib/typescript/src/utils/saveWorkoutSample.d.ts +7 -0
  199. package/lib/typescript/src/utils/serializeDate.d.ts +2 -0
  200. package/lib/typescript/src/utils/subscribeToChanges.d.ts +3 -0
  201. package/package.json +17 -6
  202. package/src/hooks/useHealthkitAuthorization.ts +39 -0
  203. package/src/hooks/useIsHealthDataAvailable.ts +17 -0
  204. package/src/hooks/useMostRecentCategorySample.ts +24 -0
  205. package/src/hooks/useMostRecentQuantitySample.ts +39 -0
  206. package/src/hooks/useMostRecentWorkout.ts +60 -0
  207. package/src/hooks/useStatisticsForQuantity.ts +42 -0
  208. package/src/hooks/useSubscribeToChanges.ts +31 -0
  209. package/src/index.ios.tsx +40 -569
  210. package/src/index.tsx +6 -7
  211. package/src/native-types.ts +327 -93
  212. package/src/types.ts +41 -152
  213. package/src/utils/deleteQuantitySample.ts +14 -0
  214. package/src/utils/deserializeCategorySample.ts +12 -0
  215. package/src/utils/deserializeCorrelation.ts +28 -0
  216. package/src/utils/deserializeSample.ts +17 -0
  217. package/src/utils/deserializeWorkout.ts +14 -0
  218. package/src/utils/ensureMetadata.ts +5 -0
  219. package/src/utils/ensureUnit.ts +19 -0
  220. package/src/utils/getDateOfBirth.ts +8 -0
  221. package/src/utils/getMostRecentCategorySample.ts +18 -0
  222. package/src/utils/getMostRecentQuantitySample.ts +19 -0
  223. package/src/utils/getMostRecentWorkout.ts +27 -0
  224. package/src/utils/getPreferredUnit.ts +14 -0
  225. package/src/utils/getPreferredUnits.ts +14 -0
  226. package/src/utils/getPreferredUnitsTyped.ts +38 -0
  227. package/src/utils/getRequestStatusForAuthorization.ts +21 -0
  228. package/src/utils/prepareOptions.ts +15 -0
  229. package/src/utils/queryCategorySamples.ts +29 -0
  230. package/src/utils/queryCorrelationSamples.ts +29 -0
  231. package/src/utils/queryQuantitySamples.ts +36 -0
  232. package/src/utils/queryStatisticsForQuantity.ts +38 -0
  233. package/src/utils/queryWorkouts.ts +28 -0
  234. package/src/utils/requestAuthorization.ts +18 -0
  235. package/src/utils/saveCategorySample.ts +27 -0
  236. package/src/utils/saveCorrelationSample.ts +34 -0
  237. package/src/utils/saveQuantitySample.ts +29 -0
  238. package/src/utils/saveWorkoutSample.ts +28 -0
  239. package/src/utils/serializeDate.ts +3 -0
  240. package/src/utils/subscribeToChanges.ts +32 -0
@@ -0,0 +1,15 @@
1
+ import { useCallback, useState } from 'react';
2
+ import getMostRecentCategorySample from '../utils/getMostRecentCategorySample';
3
+ import useSubscribeToChanges from './useSubscribeToChanges';
4
+
5
+ function useMostRecentCategorySample(identifier) {
6
+ const [category, setCategory] = useState(null);
7
+ const updater = useCallback(() => {
8
+ void getMostRecentCategorySample(identifier).then(setCategory);
9
+ }, [identifier]);
10
+ useSubscribeToChanges(identifier, updater);
11
+ return category;
12
+ }
13
+
14
+ export default useMostRecentCategorySample;
15
+ //# sourceMappingURL=useMostRecentCategorySample.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useCallback","useState","getMostRecentCategorySample","useSubscribeToChanges","useMostRecentCategorySample","identifier","category","setCategory","updater","then"],"sources":["useMostRecentCategorySample.ts"],"sourcesContent":["import { useCallback, useState } from 'react'\n\nimport getMostRecentCategorySample from '../utils/getMostRecentCategorySample'\nimport useSubscribeToChanges from './useSubscribeToChanges'\n\nimport type { HKCategoryTypeIdentifier } from '../native-types'\nimport type { HKCategorySample } from '../types'\n\nfunction useMostRecentCategorySample<\n TCategory extends HKCategoryTypeIdentifier\n>(identifier: TCategory) {\n const [category, setCategory] = useState<HKCategorySample<TCategory> | null>(\n null,\n )\n const updater = useCallback(() => {\n void getMostRecentCategorySample(identifier).then(setCategory)\n }, [identifier])\n\n useSubscribeToChanges(identifier, updater)\n\n return category\n}\n\nexport default useMostRecentCategorySample\n"],"mappings":"AAAA,SAASA,WAAT,EAAsBC,QAAtB,QAAsC,OAAtC;AAEA,OAAOC,2BAAP,MAAwC,sCAAxC;AACA,OAAOC,qBAAP,MAAkC,yBAAlC;;AAKA,SAASC,2BAAT,CAEEC,UAFF,EAEyB;EACvB,MAAM,CAACC,QAAD,EAAWC,WAAX,IAA0BN,QAAQ,CACtC,IADsC,CAAxC;EAGA,MAAMO,OAAO,GAAGR,WAAW,CAAC,MAAM;IAChC,KAAKE,2BAA2B,CAACG,UAAD,CAA3B,CAAwCI,IAAxC,CAA6CF,WAA7C,CAAL;EACD,CAF0B,EAExB,CAACF,UAAD,CAFwB,CAA3B;EAIAF,qBAAqB,CAACE,UAAD,EAAaG,OAAb,CAArB;EAEA,OAAOF,QAAP;AACD;;AAED,eAAeF,2BAAf"}
@@ -0,0 +1,30 @@
1
+ import { useEffect, useState } from 'react';
2
+ import ensureUnit from '../utils/ensureUnit';
3
+ import getMostRecentQuantitySample from '../utils/getMostRecentQuantitySample';
4
+ import subscribeToChanges from '../utils/subscribeToChanges';
5
+
6
+ function useMostRecentQuantitySample(identifier, unit) {
7
+ const [lastSample, setLastSample] = useState(null);
8
+ useEffect(() => {
9
+ let cancelSubscription;
10
+
11
+ const init = async () => {
12
+ const actualUnit = await ensureUnit(identifier, unit);
13
+ cancelSubscription = await subscribeToChanges(identifier, async () => {
14
+ const value = await getMostRecentQuantitySample(identifier, actualUnit);
15
+ setLastSample(value);
16
+ });
17
+ };
18
+
19
+ void init();
20
+ return () => {
21
+ var _cancelSubscription;
22
+
23
+ void ((_cancelSubscription = cancelSubscription) === null || _cancelSubscription === void 0 ? void 0 : _cancelSubscription());
24
+ };
25
+ }, [identifier, unit]);
26
+ return lastSample;
27
+ }
28
+
29
+ export default useMostRecentQuantitySample;
30
+ //# sourceMappingURL=useMostRecentQuantitySample.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useEffect","useState","ensureUnit","getMostRecentQuantitySample","subscribeToChanges","useMostRecentQuantitySample","identifier","unit","lastSample","setLastSample","cancelSubscription","init","actualUnit","value"],"sources":["useMostRecentQuantitySample.ts"],"sourcesContent":["import { useEffect, useState } from 'react'\n\nimport ensureUnit from '../utils/ensureUnit'\nimport getMostRecentQuantitySample from '../utils/getMostRecentQuantitySample'\nimport subscribeToChanges from '../utils/subscribeToChanges'\n\nimport type { HKQuantityTypeIdentifier, UnitForIdentifier } from '../native-types'\nimport type { HKQuantitySample } from '../types'\n\nfunction useMostRecentQuantitySample<\n TIdentifier extends HKQuantityTypeIdentifier,\n TUnit extends UnitForIdentifier<TIdentifier>\n>(identifier: TIdentifier, unit?: TUnit) {\n const [lastSample, setLastSample] = useState<HKQuantitySample<\n TIdentifier\n > | null>(null)\n\n useEffect(() => {\n let cancelSubscription: (() => Promise<boolean>) | undefined\n\n const init = async () => {\n const actualUnit = await ensureUnit(identifier, unit)\n\n cancelSubscription = await subscribeToChanges(identifier, async () => {\n const value = await getMostRecentQuantitySample(identifier, actualUnit)\n setLastSample(value)\n })\n }\n void init()\n\n return () => {\n void cancelSubscription?.()\n }\n }, [identifier, unit])\n\n return lastSample\n}\n\nexport default useMostRecentQuantitySample\n"],"mappings":"AAAA,SAASA,SAAT,EAAoBC,QAApB,QAAoC,OAApC;AAEA,OAAOC,UAAP,MAAuB,qBAAvB;AACA,OAAOC,2BAAP,MAAwC,sCAAxC;AACA,OAAOC,kBAAP,MAA+B,6BAA/B;;AAKA,SAASC,2BAAT,CAGEC,UAHF,EAG2BC,IAH3B,EAGyC;EACvC,MAAM,CAACC,UAAD,EAAaC,aAAb,IAA8BR,QAAQ,CAElC,IAFkC,CAA5C;EAIAD,SAAS,CAAC,MAAM;IACd,IAAIU,kBAAJ;;IAEA,MAAMC,IAAI,GAAG,YAAY;MACvB,MAAMC,UAAU,GAAG,MAAMV,UAAU,CAACI,UAAD,EAAaC,IAAb,CAAnC;MAEAG,kBAAkB,GAAG,MAAMN,kBAAkB,CAACE,UAAD,EAAa,YAAY;QACpE,MAAMO,KAAK,GAAG,MAAMV,2BAA2B,CAACG,UAAD,EAAaM,UAAb,CAA/C;QACAH,aAAa,CAACI,KAAD,CAAb;MACD,CAH4C,CAA7C;IAID,CAPD;;IAQA,KAAKF,IAAI,EAAT;IAEA,OAAO,MAAM;MAAA;;MACX,6BAAKD,kBAAL,wDAAK,qBAAL;IACD,CAFD;EAGD,CAhBQ,EAgBN,CAACJ,UAAD,EAAaC,IAAb,CAhBM,CAAT;EAkBA,OAAOC,UAAP;AACD;;AAED,eAAeH,2BAAf"}
@@ -0,0 +1,47 @@
1
+ import { useEffect, useState, useRef, useCallback } from 'react';
2
+ import getMostRecentWorkout from '../utils/getMostRecentWorkout';
3
+ import getPreferredUnitsTyped from '../utils/getPreferredUnitsTyped';
4
+ import subscribeToChanges from '../utils/subscribeToChanges';
5
+
6
+ function useMostRecentWorkout(options) {
7
+ const [workout, setWorkout] = useState(null);
8
+ const optionsRef = useRef(options);
9
+ useEffect(() => {
10
+ optionsRef.current = options;
11
+ }, [options]);
12
+ const update = useCallback(async () => {
13
+ const {
14
+ energyUnit,
15
+ distanceUnit
16
+ } = await getPreferredUnitsTyped(optionsRef.current);
17
+ console.log({
18
+ energyUnit,
19
+ distanceUnit
20
+ });
21
+ setWorkout(await getMostRecentWorkout({
22
+ energyUnit,
23
+ distanceUnit
24
+ }));
25
+ }, []);
26
+ useEffect(() => {
27
+ void update();
28
+ }, [update]);
29
+ useEffect(() => {
30
+ let cancelSubscription;
31
+
32
+ const init = async () => {
33
+ cancelSubscription = await subscribeToChanges('HKWorkoutTypeIdentifier', update);
34
+ };
35
+
36
+ void init();
37
+ return () => {
38
+ var _cancelSubscription;
39
+
40
+ void ((_cancelSubscription = cancelSubscription) === null || _cancelSubscription === void 0 ? void 0 : _cancelSubscription());
41
+ };
42
+ }, [update]);
43
+ return workout;
44
+ }
45
+
46
+ export default useMostRecentWorkout;
47
+ //# sourceMappingURL=useMostRecentWorkout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useEffect","useState","useRef","useCallback","getMostRecentWorkout","getPreferredUnitsTyped","subscribeToChanges","useMostRecentWorkout","options","workout","setWorkout","optionsRef","current","update","energyUnit","distanceUnit","console","log","cancelSubscription","init"],"sources":["useMostRecentWorkout.ts"],"sourcesContent":["import {\n useEffect, useState, useRef, useCallback,\n} from 'react'\n\nimport getMostRecentWorkout from '../utils/getMostRecentWorkout'\nimport getPreferredUnitsTyped from '../utils/getPreferredUnitsTyped'\nimport subscribeToChanges from '../utils/subscribeToChanges'\n\nimport type { EnergyUnit, LengthUnit } from '../native-types'\nimport type { HKWorkout } from '../types'\n\nfunction useMostRecentWorkout<\n TEnergy extends EnergyUnit,\n TDistance extends LengthUnit\n>(options?: { readonly energyUnit?: TEnergy; readonly distanceUnit?: TDistance }) {\n const [workout, setWorkout] = useState<HKWorkout<TEnergy, TDistance> | null>(null)\n\n const optionsRef = useRef(options)\n\n useEffect(() => {\n optionsRef.current = options\n }, [options])\n\n const update = useCallback(async () => {\n const { energyUnit, distanceUnit } = await getPreferredUnitsTyped(\n optionsRef.current,\n )\n\n console.log({ energyUnit, distanceUnit })\n\n setWorkout(await getMostRecentWorkout({\n energyUnit,\n distanceUnit,\n }))\n }, [])\n\n useEffect(() => {\n void update()\n }, [update])\n\n useEffect(() => {\n let cancelSubscription: (() => Promise<boolean>) | undefined\n\n const init = async () => {\n cancelSubscription = await subscribeToChanges(\n 'HKWorkoutTypeIdentifier',\n update,\n )\n }\n void init()\n\n return () => {\n void cancelSubscription?.()\n }\n }, [update])\n\n return workout\n}\n\nexport default useMostRecentWorkout\n"],"mappings":"AAAA,SACEA,SADF,EACaC,QADb,EACuBC,MADvB,EAC+BC,WAD/B,QAEO,OAFP;AAIA,OAAOC,oBAAP,MAAiC,+BAAjC;AACA,OAAOC,sBAAP,MAAmC,iCAAnC;AACA,OAAOC,kBAAP,MAA+B,6BAA/B;;AAKA,SAASC,oBAAT,CAGEC,OAHF,EAGkF;EAChF,MAAM,CAACC,OAAD,EAAUC,UAAV,IAAwBT,QAAQ,CAAuC,IAAvC,CAAtC;EAEA,MAAMU,UAAU,GAAGT,MAAM,CAACM,OAAD,CAAzB;EAEAR,SAAS,CAAC,MAAM;IACdW,UAAU,CAACC,OAAX,GAAqBJ,OAArB;EACD,CAFQ,EAEN,CAACA,OAAD,CAFM,CAAT;EAIA,MAAMK,MAAM,GAAGV,WAAW,CAAC,YAAY;IACrC,MAAM;MAAEW,UAAF;MAAcC;IAAd,IAA+B,MAAMV,sBAAsB,CAC/DM,UAAU,CAACC,OADoD,CAAjE;IAIAI,OAAO,CAACC,GAAR,CAAY;MAAEH,UAAF;MAAcC;IAAd,CAAZ;IAEAL,UAAU,CAAC,MAAMN,oBAAoB,CAAC;MACpCU,UADoC;MAEpCC;IAFoC,CAAD,CAA3B,CAAV;EAID,CAXyB,EAWvB,EAXuB,CAA1B;EAaAf,SAAS,CAAC,MAAM;IACd,KAAKa,MAAM,EAAX;EACD,CAFQ,EAEN,CAACA,MAAD,CAFM,CAAT;EAIAb,SAAS,CAAC,MAAM;IACd,IAAIkB,kBAAJ;;IAEA,MAAMC,IAAI,GAAG,YAAY;MACvBD,kBAAkB,GAAG,MAAMZ,kBAAkB,CAC3C,yBAD2C,EAE3CO,MAF2C,CAA7C;IAID,CALD;;IAMA,KAAKM,IAAI,EAAT;IAEA,OAAO,MAAM;MAAA;;MACX,6BAAKD,kBAAL,wDAAK,qBAAL;IACD,CAFD;EAGD,CAdQ,EAcN,CAACL,MAAD,CAdM,CAAT;EAgBA,OAAOJ,OAAP;AACD;;AAED,eAAeF,oBAAf"}
@@ -0,0 +1,23 @@
1
+ import { useState, useEffect, useCallback, useRef } from 'react';
2
+ import queryStatisticsForQuantity from '../utils/queryStatisticsForQuantity';
3
+ import useSubscribeToChanges from './useSubscribeToChanges';
4
+
5
+ function useStatisticsForQuantity(identifier, options, from, to, unit) {
6
+ const [result, setResult] = useState(null);
7
+ const optionsRef = useRef(options);
8
+ useEffect(() => {
9
+ optionsRef.current = options;
10
+ }, [options]);
11
+ const update = useCallback(async () => {
12
+ const res = await queryStatisticsForQuantity(identifier, optionsRef.current, from, to, unit);
13
+ setResult(res);
14
+ }, [identifier, from, to, unit]);
15
+ useEffect(() => {
16
+ void update();
17
+ }, [update]);
18
+ useSubscribeToChanges(identifier, update);
19
+ return result;
20
+ }
21
+
22
+ export default useStatisticsForQuantity;
23
+ //# sourceMappingURL=useStatisticsForQuantity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useState","useEffect","useCallback","useRef","queryStatisticsForQuantity","useSubscribeToChanges","useStatisticsForQuantity","identifier","options","from","to","unit","result","setResult","optionsRef","current","update","res"],"sources":["useStatisticsForQuantity.ts"],"sourcesContent":["import {\n useState, useEffect, useCallback, useRef,\n} from 'react'\n\nimport queryStatisticsForQuantity from '../utils/queryStatisticsForQuantity'\nimport useSubscribeToChanges from './useSubscribeToChanges'\n\nimport type { HKQuantityTypeIdentifier, HKStatisticsOptions, UnitForIdentifier } from '../native-types'\nimport type { QueryStatisticsResponse } from '../types'\n\nfunction useStatisticsForQuantity<TIdentifier extends HKQuantityTypeIdentifier, TUnit extends UnitForIdentifier<TIdentifier> = UnitForIdentifier<TIdentifier>>(\n identifier: TIdentifier,\n options: readonly HKStatisticsOptions[],\n from: Date,\n to?: Date,\n unit?: TUnit,\n) {\n const [result, setResult] = useState<QueryStatisticsResponse<TIdentifier, TUnit> | null>(null)\n\n const optionsRef = useRef(options)\n\n useEffect(() => {\n optionsRef.current = options\n }, [options])\n\n const update = useCallback(async () => {\n const res = await queryStatisticsForQuantity(identifier, optionsRef.current, from, to, unit)\n setResult(res)\n }, [\n identifier, from, to, unit,\n ])\n\n useEffect(() => {\n void update()\n }, [update])\n\n useSubscribeToChanges(identifier, update)\n\n return result\n}\n\nexport default useStatisticsForQuantity\n"],"mappings":"AAAA,SACEA,QADF,EACYC,SADZ,EACuBC,WADvB,EACoCC,MADpC,QAEO,OAFP;AAIA,OAAOC,0BAAP,MAAuC,qCAAvC;AACA,OAAOC,qBAAP,MAAkC,yBAAlC;;AAKA,SAASC,wBAAT,CACEC,UADF,EAEEC,OAFF,EAGEC,IAHF,EAIEC,EAJF,EAKEC,IALF,EAME;EACA,MAAM,CAACC,MAAD,EAASC,SAAT,IAAsBb,QAAQ,CAAqD,IAArD,CAApC;EAEA,MAAMc,UAAU,GAAGX,MAAM,CAACK,OAAD,CAAzB;EAEAP,SAAS,CAAC,MAAM;IACda,UAAU,CAACC,OAAX,GAAqBP,OAArB;EACD,CAFQ,EAEN,CAACA,OAAD,CAFM,CAAT;EAIA,MAAMQ,MAAM,GAAGd,WAAW,CAAC,YAAY;IACrC,MAAMe,GAAG,GAAG,MAAMb,0BAA0B,CAACG,UAAD,EAAaO,UAAU,CAACC,OAAxB,EAAiCN,IAAjC,EAAuCC,EAAvC,EAA2CC,IAA3C,CAA5C;IACAE,SAAS,CAACI,GAAD,CAAT;EACD,CAHyB,EAGvB,CACDV,UADC,EACWE,IADX,EACiBC,EADjB,EACqBC,IADrB,CAHuB,CAA1B;EAOAV,SAAS,CAAC,MAAM;IACd,KAAKe,MAAM,EAAX;EACD,CAFQ,EAEN,CAACA,MAAD,CAFM,CAAT;EAIAX,qBAAqB,CAACE,UAAD,EAAaS,MAAb,CAArB;EAEA,OAAOJ,MAAP;AACD;;AAED,eAAeN,wBAAf"}
@@ -0,0 +1,26 @@
1
+ import { useEffect, useRef } from 'react';
2
+ import subscribeToChanges from '../utils/subscribeToChanges';
3
+
4
+ function useSubscribeToChanges(identifier, onChange) {
5
+ const onChangeRef = useRef(onChange);
6
+ useEffect(() => {
7
+ onChangeRef.current = onChange;
8
+ }, [onChange]);
9
+ useEffect(() => {
10
+ let cancelSubscription;
11
+
12
+ const init = async () => {
13
+ cancelSubscription = await subscribeToChanges(identifier, onChangeRef.current);
14
+ };
15
+
16
+ void init();
17
+ return () => {
18
+ var _cancelSubscription;
19
+
20
+ void ((_cancelSubscription = cancelSubscription) === null || _cancelSubscription === void 0 ? void 0 : _cancelSubscription());
21
+ };
22
+ }, [identifier]);
23
+ }
24
+
25
+ export default useSubscribeToChanges;
26
+ //# sourceMappingURL=useSubscribeToChanges.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useEffect","useRef","subscribeToChanges","useSubscribeToChanges","identifier","onChange","onChangeRef","current","cancelSubscription","init"],"sources":["useSubscribeToChanges.ts"],"sourcesContent":["import { useEffect, useRef } from 'react'\n\nimport subscribeToChanges from '../utils/subscribeToChanges'\n\nimport type { HKSampleTypeIdentifier } from '..'\n\nfunction useSubscribeToChanges<TIdentifier extends HKSampleTypeIdentifier>(\n identifier: TIdentifier,\n onChange: () => void,\n): void {\n const onChangeRef = useRef(onChange)\n\n useEffect(() => {\n onChangeRef.current = onChange\n }, [onChange])\n\n useEffect(() => {\n let cancelSubscription: (() => Promise<boolean>) | undefined\n\n const init = async () => {\n cancelSubscription = await subscribeToChanges(identifier, onChangeRef.current)\n }\n void init()\n\n return () => {\n void cancelSubscription?.()\n }\n }, [identifier])\n}\n\nexport default useSubscribeToChanges\n"],"mappings":"AAAA,SAASA,SAAT,EAAoBC,MAApB,QAAkC,OAAlC;AAEA,OAAOC,kBAAP,MAA+B,6BAA/B;;AAIA,SAASC,qBAAT,CACEC,UADF,EAEEC,QAFF,EAGQ;EACN,MAAMC,WAAW,GAAGL,MAAM,CAACI,QAAD,CAA1B;EAEAL,SAAS,CAAC,MAAM;IACdM,WAAW,CAACC,OAAZ,GAAsBF,QAAtB;EACD,CAFQ,EAEN,CAACA,QAAD,CAFM,CAAT;EAIAL,SAAS,CAAC,MAAM;IACd,IAAIQ,kBAAJ;;IAEA,MAAMC,IAAI,GAAG,YAAY;MACvBD,kBAAkB,GAAG,MAAMN,kBAAkB,CAACE,UAAD,EAAaE,WAAW,CAACC,OAAzB,CAA7C;IACD,CAFD;;IAGA,KAAKE,IAAI,EAAT;IAEA,OAAO,MAAM;MAAA;;MACX,6BAAKD,kBAAL,wDAAK,qBAAL;IACD,CAFD;EAGD,CAXQ,EAWN,CAACJ,UAAD,CAXM,CAAT;AAYD;;AAED,eAAeD,qBAAf"}
@@ -1,350 +1,41 @@
1
- import { useCallback, useEffect, useState } from 'react';
2
- import Native, { EventEmitter, HKQuantityTypeIdentifier, HKUnit } from './native-types';
3
-
4
- const getPreferredUnit = async type => {
5
- const [unit] = await getPreferredUnits([type]);
6
- return unit;
7
- };
8
-
9
- const ensureUnit = async (type, providedUnit) => {
10
- if (providedUnit) {
11
- return providedUnit;
12
- }
13
-
14
- const unit = await Native.getPreferredUnits([type]);
15
- return unit[type];
16
- };
17
-
18
- function deserializeSample(sample) {
19
- return { ...sample,
20
- startDate: new Date(sample.startDate),
21
- endDate: new Date(sample.endDate)
22
- };
23
- }
24
-
25
- function deserializeWorkout(sample) {
26
- return { ...sample,
27
- startDate: new Date(sample.startDate),
28
- endDate: new Date(sample.endDate)
29
- };
30
- }
31
-
32
- const deserializCategorySample = sample => ({ ...sample,
33
- startDate: new Date(sample.startDate),
34
- endDate: new Date(sample.endDate)
35
- });
36
-
37
- const serializeDate = date => date ? date.toISOString() : new Date(0).toISOString();
38
-
39
- const prepareOptions = options => {
40
- const limit = !options.limit || options.limit === Infinity ? 0 : options.limit;
41
- const ascending = options.ascending ?? limit === 0;
42
- const from = serializeDate(options.from);
43
- const to = serializeDate(options.to);
44
- return {
45
- limit,
46
- ascending,
47
- from,
48
- to
49
- };
50
- };
51
-
52
- const queryQuantitySamples = async (identifier, options) => {
53
- const unit = await ensureUnit(identifier, options.unit);
54
- const opts = prepareOptions(options);
55
- const quantitySamples = await Native.queryQuantitySamples(identifier, unit, opts.from, opts.to, opts.limit, opts.ascending);
56
- return quantitySamples.map(deserializeSample);
57
- };
58
-
59
- async function getPreferredUnitsTyped(options) {
60
- let energyUnit = options === null || options === void 0 ? void 0 : options.energyUnit;
61
- let distanceUnit = options === null || options === void 0 ? void 0 : options.distanceUnit;
62
-
63
- if (!energyUnit || !distanceUnit) {
64
- const units = await Native.getPreferredUnits([HKQuantityTypeIdentifier.distanceWalkingRunning, HKQuantityTypeIdentifier.activeEnergyBurned]);
65
-
66
- if (!energyUnit) {
67
- energyUnit = units[HKQuantityTypeIdentifier.distanceWalkingRunning];
68
- }
69
-
70
- if (!distanceUnit) {
71
- distanceUnit = units[HKQuantityTypeIdentifier.activeEnergyBurned];
72
- }
73
- }
74
-
75
- if (!energyUnit) {
76
- energyUnit = HKUnit.Kilocalories;
77
- }
78
-
79
- if (!distanceUnit) {
80
- distanceUnit = HKUnit.Meters;
81
- }
82
-
83
- return {
84
- energyUnit,
85
- distanceUnit
86
- };
87
- }
88
-
89
- const subscribeToChanges = async (identifier, callback) => {
90
- const subscription = EventEmitter.addListener('onChange', _ref => {
91
- let {
92
- typeIdentifier
93
- } = _ref;
94
-
95
- if (typeIdentifier === identifier) {
96
- callback();
97
- }
98
- });
99
- const queryId = await Native.subscribeToObserverQuery(identifier).catch(async error => {
100
- subscription.remove();
101
- return Promise.reject(error);
102
- });
103
- return async () => {
104
- subscription.remove();
105
- return Native.unsubscribeQuery(queryId);
106
- };
107
- };
108
-
109
- const getMostRecentQuantitySample = async (identifier, unit) => {
110
- const samples = await queryQuantitySamples(identifier, {
111
- limit: 1,
112
- unit
113
- });
114
- return samples[0];
115
- };
116
-
117
- function useMostRecentWorkout(options) {
118
- const [workout, setWorkout] = useState(null);
119
- useEffect(() => {
120
- let cancelSubscription;
121
-
122
- const init = async () => {
123
- const {
124
- energyUnit,
125
- distanceUnit
126
- } = await getPreferredUnitsTyped(options);
127
- cancelSubscription = await subscribeToChanges('HKWorkoutTypeIdentifier', async () => {
128
- const w = await getMostRecentWorkout({
129
- energyUnit,
130
- distanceUnit
131
- });
132
- setWorkout(w);
133
- });
134
- };
135
-
136
- void init();
137
- return () => {
138
- var _cancelSubscription;
139
-
140
- void ((_cancelSubscription = cancelSubscription) === null || _cancelSubscription === void 0 ? void 0 : _cancelSubscription());
141
- };
142
- }, [options]);
143
- return workout;
144
- }
145
-
146
- const getMostRecentCategorySample = async identifier => {
147
- const samples = await queryCategorySamples(identifier, {
148
- limit: 1,
149
- ascending: false
150
- });
151
- return samples[0];
152
- };
153
-
154
- function useSubscribeToChanges(identifier, onChange) {
155
- useEffect(() => {
156
- let cancelSubscription;
157
-
158
- const init = async () => {
159
- cancelSubscription = await subscribeToChanges(identifier, onChange);
160
- };
161
-
162
- void init();
163
- return () => {
164
- var _cancelSubscription2;
165
-
166
- void ((_cancelSubscription2 = cancelSubscription) === null || _cancelSubscription2 === void 0 ? void 0 : _cancelSubscription2());
167
- };
168
- }, [identifier, onChange]);
169
- }
170
-
171
- function useMostRecentCategorySample(identifier) {
172
- const [category, setCategory] = useState(null);
173
- const updater = useCallback(() => {
174
- void getMostRecentCategorySample(identifier).then(setCategory);
175
- }, [identifier]);
176
- useSubscribeToChanges(identifier, updater);
177
- return category;
178
- }
179
-
180
- function useMostRecentQuantitySample(identifier, unit) {
181
- const [lastSample, setLastSample] = useState(null);
182
- useEffect(() => {
183
- let cancelSubscription;
184
-
185
- const init = async () => {
186
- const actualUnit = await ensureUnit(identifier, unit);
187
- cancelSubscription = await subscribeToChanges(identifier, async () => {
188
- const value = await getMostRecentQuantitySample(identifier, actualUnit);
189
- setLastSample(value);
190
- });
191
- };
192
-
193
- void init();
194
- return () => {
195
- var _cancelSubscription3;
196
-
197
- void ((_cancelSubscription3 = cancelSubscription) === null || _cancelSubscription3 === void 0 ? void 0 : _cancelSubscription3());
198
- };
199
- }, [identifier, unit]);
200
- return lastSample;
201
- }
202
-
203
- const saveQuantitySample = async (identifier, unit, value, options) => {
204
- const start = (options === null || options === void 0 ? void 0 : options.start) || (options === null || options === void 0 ? void 0 : options.end) || new Date();
205
- const end = (options === null || options === void 0 ? void 0 : options.end) || (options === null || options === void 0 ? void 0 : options.start) || new Date();
206
- const metadata = (options === null || options === void 0 ? void 0 : options.metadata) || {};
207
- return Native.saveQuantitySample(identifier, unit, value, start.toISOString(), end.toISOString(), metadata);
208
- };
209
-
210
- const queryStatisticsForQuantity = async (identifier, options, from, to, unit) => {
211
- const actualUnit = await ensureUnit(identifier, unit);
212
- const toDate = to || new Date();
213
- const {
214
- mostRecentQuantityDateInterval,
215
- ...rawResponse
216
- } = await Native.queryStatisticsForQuantity(identifier, actualUnit, from.toISOString(), toDate.toISOString(), options);
217
- const response = { ...rawResponse,
218
- ...(mostRecentQuantityDateInterval ? {
219
- mostRecentQuantityDateInterval: {
220
- from: new Date(mostRecentQuantityDateInterval.from),
221
- to: new Date(mostRecentQuantityDateInterval.to)
222
- }
223
- } : {})
224
- };
225
- return response;
226
- };
227
-
228
- const requestAuthorization = async function (read) {
229
- let write = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
230
- const readPermissions = read.reduce((obj, cur) => ({ ...obj,
231
- [cur]: true
232
- }), {});
233
- const writePermissions = write.reduce((obj, cur) => ({ ...obj,
234
- [cur]: true
235
- }), {});
236
- return Native.requestAuthorization(writePermissions, readPermissions);
237
- };
238
-
239
- const getDateOfBirth = async () => {
240
- const dateOfBirth = await Native.getDateOfBirth();
241
- return new Date(dateOfBirth);
242
- };
243
-
244
- const getRequestStatusForAuthorization = async function (read) {
245
- let write = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
246
- const readPermissions = read.reduce((obj, cur) => ({ ...obj,
247
- [cur]: true
248
- }), {});
249
- const writePermissions = write.reduce((obj, cur) => ({ ...obj,
250
- [cur]: true
251
- }), {});
252
- return Native.getRequestStatusForAuthorization(writePermissions, readPermissions);
253
- };
254
-
255
- const queryCategorySamples = async (identifier, options) => {
256
- const opts = prepareOptions(options);
257
- const results = await Native.queryCategorySamples(identifier, opts.from, opts.to, opts.limit, opts.ascending);
258
- return results.map(deserializCategorySample);
259
- };
260
-
261
- const queryWorkouts = async options => {
262
- const {
263
- energyUnit,
264
- distanceUnit
265
- } = await getPreferredUnitsTyped(options);
266
- const opts = prepareOptions(options);
267
- const workouts = await Native.queryWorkoutSamples(energyUnit, distanceUnit, opts.from, opts.to, opts.limit, opts.ascending);
268
- return workouts.map(deserializeWorkout);
269
- };
270
-
271
- const getMostRecentWorkout = async options => {
272
- const workouts = await queryWorkouts({
273
- limit: 1,
274
- ascending: false,
275
- energyUnit: options === null || options === void 0 ? void 0 : options.energyUnit,
276
- distanceUnit: options === null || options === void 0 ? void 0 : options.distanceUnit
277
- });
278
- return workouts[0];
279
- };
280
-
281
- async function saveCategorySample(identifier, value, options) {
282
- const start = (options === null || options === void 0 ? void 0 : options.start) || (options === null || options === void 0 ? void 0 : options.end) || new Date();
283
- const end = (options === null || options === void 0 ? void 0 : options.end) || (options === null || options === void 0 ? void 0 : options.start) || new Date();
284
- const metadata = (options === null || options === void 0 ? void 0 : options.metadata) || {};
285
- return Native.saveCategorySample(identifier, value, start.toISOString(), end.toISOString(), metadata || {});
286
- }
287
-
288
- const getPreferredUnits = async identifiers => {
289
- const units = await Native.getPreferredUnits(identifiers);
290
- return identifiers.map(i => units[i]);
291
- };
292
-
293
- const buildUnitWithPrefix = (prefix, unit) => `${prefix}${unit}`;
294
-
295
- function deserializeCorrelation(s) {
296
- return { ...s,
297
- objects: s.objects.map(o => {
298
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
299
- // @ts-ignore
300
- if (o.quantity !== undefined) {
301
- return deserializeSample(o);
302
- }
303
-
304
- return deserializCategorySample(o);
305
- }),
306
- endDate: new Date(s.endDate),
307
- startDate: new Date(s.startDate)
308
- };
309
- }
310
-
311
- function ensureMetadata(metadata) {
312
- return metadata || {};
313
- }
314
-
315
- const queryCorrelationSamples = async (typeIdentifier, options) => {
316
- const opts = prepareOptions(options);
317
- const correlations = await Native.queryCorrelationSamples(typeIdentifier, opts.from, opts.to);
318
- return correlations.map(deserializeCorrelation);
319
- };
320
-
321
- const saveCorrelationSample = async (typeIdentifier, samples, options) => {
322
- const start = ((options === null || options === void 0 ? void 0 : options.start) || new Date()).toISOString();
323
- const end = ((options === null || options === void 0 ? void 0 : options.end) || new Date()).toISOString();
324
- return Native.saveCorrelationSample(typeIdentifier, samples, start, end, ensureMetadata(options === null || options === void 0 ? void 0 : options.metadata));
325
- };
326
-
327
- const saveWorkoutSample = async (typeIdentifier, quantities, _start, options) => {
328
- const start = _start.toISOString();
329
-
330
- const end = ((options === null || options === void 0 ? void 0 : options.end) || new Date()).toISOString();
331
- return Native.saveWorkoutSample(typeIdentifier, quantities, start, end, ensureMetadata(options === null || options === void 0 ? void 0 : options.metadata));
332
- };
333
-
334
- const getWorkoutRoutes = async workoutUUID => Native.getWorkoutRoutes(workoutUUID);
335
-
1
+ import useHealthkitAuthorization from './hooks/useHealthkitAuthorization';
2
+ import useIsHealthDataAvailable from './hooks/useIsHealthDataAvailable';
3
+ import useMostRecentCategorySample from './hooks/useMostRecentCategorySample';
4
+ import useMostRecentQuantitySample from './hooks/useMostRecentQuantitySample';
5
+ import useMostRecentWorkout from './hooks/useMostRecentWorkout';
6
+ import useSubscribeToChanges from './hooks/useSubscribeToChanges';
7
+ import Native from './native-types';
8
+ import deleteQuantitySample from './utils/deleteQuantitySample';
9
+ import getDateOfBirth from './utils/getDateOfBirth';
10
+ import getMostRecentCategorySample from './utils/getMostRecentCategorySample';
11
+ import getMostRecentQuantitySample from './utils/getMostRecentQuantitySample';
12
+ import getMostRecentWorkout from './utils/getMostRecentWorkout';
13
+ import getPreferredUnit from './utils/getPreferredUnit';
14
+ import getPreferredUnits from './utils/getPreferredUnits';
15
+ import getRequestStatusForAuthorization from './utils/getRequestStatusForAuthorization';
16
+ import queryCategorySamples from './utils/queryCategorySamples';
17
+ import queryCorrelationSamples from './utils/queryCorrelationSamples';
18
+ import queryQuantitySamples from './utils/queryQuantitySamples';
19
+ import queryStatisticsForQuantity from './utils/queryStatisticsForQuantity';
20
+ import queryWorkouts from './utils/queryWorkouts';
21
+ import requestAuthorization from './utils/requestAuthorization';
22
+ import saveCategorySample from './utils/saveCategorySample';
23
+ import saveCorrelationSample from './utils/saveCorrelationSample';
24
+ import saveQuantitySample from './utils/saveQuantitySample';
25
+ import saveWorkoutSample from './utils/saveWorkoutSample';
26
+ import subscribeToChanges from './utils/subscribeToChanges';
336
27
  const Healthkit = {
337
28
  authorizationStatusFor: Native.authorizationStatusFor.bind(Native),
338
29
  isHealthDataAvailable: Native.isHealthDataAvailable.bind(Native),
339
- buildUnitWithPrefix,
340
- disableAllBackgroundDelivery: Native.disableAllBackgroundDelivery,
341
- disableBackgroundDelivery: Native.disableBackgroundDelivery,
342
- enableBackgroundDelivery: Native.enableBackgroundDelivery,
30
+ disableAllBackgroundDelivery: Native.disableAllBackgroundDelivery.bind(Native),
31
+ disableBackgroundDelivery: Native.disableBackgroundDelivery.bind(Native),
32
+ enableBackgroundDelivery: Native.enableBackgroundDelivery.bind(Native),
343
33
  // simple convenience getters
344
34
  getBiologicalSex: Native.getBiologicalSex.bind(Native),
345
35
  getFitzpatrickSkinType: Native.getFitzpatrickSkinType.bind(Native),
346
- getWheelchairUse: Native.getWheelchairUse,
36
+ getWheelchairUse: Native.getWheelchairUse.bind(Native),
347
37
  getBloodType: Native.getBloodType.bind(Native),
38
+ getWorkoutRoutes: Native.getWorkoutRoutes.bind(Native),
348
39
  getDateOfBirth,
349
40
  getMostRecentQuantitySample,
350
41
  getMostRecentCategorySample,
@@ -352,7 +43,6 @@ const Healthkit = {
352
43
  getPreferredUnit,
353
44
  getPreferredUnits,
354
45
  getRequestStatusForAuthorization,
355
- getWorkoutRoutes,
356
46
  // query methods
357
47
  queryCategorySamples,
358
48
  queryCorrelationSamples,
@@ -360,6 +50,8 @@ const Healthkit = {
360
50
  queryStatisticsForQuantity,
361
51
  queryWorkouts,
362
52
  requestAuthorization,
53
+ // delete methods
54
+ deleteQuantitySample,
363
55
  // save methods
364
56
  saveCategorySample,
365
57
  saveCorrelationSample,
@@ -372,36 +64,9 @@ const Healthkit = {
372
64
  useMostRecentQuantitySample,
373
65
  useMostRecentWorkout,
374
66
  useSubscribeToChanges,
375
- useIsHealthDataAvailable: () => {
376
- const [isAvailable, setIsAvailable] = useState(null);
377
- useEffect(() => {
378
- const init = async () => {
379
- const res = await Native.isHealthDataAvailable();
380
- setIsAvailable(res);
381
- };
382
-
383
- void init();
384
- }, []);
385
- return isAvailable;
386
- },
387
- useHealthkitAuthorization: (read, write) => {
388
- const [status, setStatus] = useState(null);
389
- const refreshAuthStatus = useCallback(async () => {
390
- const auth = await getRequestStatusForAuthorization(read, write);
391
- setStatus(auth);
392
- return auth;
393
- }, []);
394
- const request = useCallback(async () => {
395
- await requestAuthorization(read, write);
396
- return refreshAuthStatus();
397
- }, []);
398
- useEffect(() => {
399
- void refreshAuthStatus();
400
- }, []);
401
- return [status, request];
402
- }
67
+ useIsHealthDataAvailable,
68
+ useHealthkitAuthorization
403
69
  };
404
- export * from './native-types';
405
70
  export * from './types';
406
71
  export default Healthkit;
407
72
  //# sourceMappingURL=index.ios.js.map