hevy-shared 1.0.1048 → 1.0.1050
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/built/hevyTrainer.d.ts +34 -43
- package/built/hevyTrainer.js +64 -65
- package/built/index.d.ts +113 -8
- package/built/index.js +1 -1
- package/built/tests/hevyTrainer.test.js +62 -75
- package/built/tests/testUtils.js +1 -0
- package/built/workout/index.d.ts +3 -3
- package/built/workout/index.js +3 -2
- package/built/workout/normalizedWorkout.d.ts +1 -0
- package/built/workout/postWorkoutRequest.d.ts +1 -0
- package/built/workout/publicWorkout.d.ts +3 -1
- package/built/workout/userWorkout.d.ts +29 -1
- package/built/workout/workout.d.ts +37 -1
- package/package.json +1 -1
- package/built/geography.d.ts +0 -1
- package/built/geography.js +0 -15
- package/built/tests/geography.test.d.ts +0 -1
- package/built/tests/geography.test.js +0 -25
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DistanceUnit, ExerciseType, MuscleGroup, RPE, SetPersonalRecordType, SetType, WeightUnit } from '..';
|
|
1
|
+
import { DistanceUnit, Equipment, ExerciseType, MuscleGroup, RPE, SetPersonalRecordType, SetType, WeightUnit } from '..';
|
|
2
2
|
export declare const isPublicWorkout: (x: any) => x is PublicWorkout;
|
|
3
3
|
export interface PublicWorkout {
|
|
4
4
|
type: 'public';
|
|
@@ -39,9 +39,11 @@ export interface PublicWorkoutExercise {
|
|
|
39
39
|
superset_id: number | null;
|
|
40
40
|
rest_seconds: number | null;
|
|
41
41
|
notes: string;
|
|
42
|
+
priority: number;
|
|
42
43
|
muscle_group: MuscleGroup;
|
|
43
44
|
other_muscles: MuscleGroup[];
|
|
44
45
|
exercise_type: ExerciseType;
|
|
46
|
+
equipment_category: Equipment;
|
|
45
47
|
url?: string;
|
|
46
48
|
media_type?: string;
|
|
47
49
|
custom_exercise_image_url?: string | null;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ExerciseType, MuscleGroup, PreviewWorkoutLike, RPE, SetPersonalRecordType, SetType, WorkoutBiometrics, WorkoutComment, WorkoutMedia } from '..';
|
|
1
|
+
import { Equipment, ExerciseType, MuscleGroup, PreviewWorkoutLike, RPE, SetPersonalRecordType, SetType, WorkoutBiometrics, WorkoutComment, WorkoutMedia } from '..';
|
|
2
2
|
export interface UserWorkout {
|
|
3
3
|
id: string;
|
|
4
4
|
short_id: string | null;
|
|
@@ -6,9 +6,13 @@ export interface UserWorkout {
|
|
|
6
6
|
name: string;
|
|
7
7
|
description?: string;
|
|
8
8
|
like_count: number;
|
|
9
|
+
/** @deprecated 2.3.4 */
|
|
10
|
+
like_images: string[];
|
|
9
11
|
preview_workout_likes: PreviewWorkoutLike[];
|
|
10
12
|
comment_count: number;
|
|
11
13
|
comments: WorkoutComment[];
|
|
14
|
+
/** @deprecated 1.28.13 */
|
|
15
|
+
image_urls?: string[];
|
|
12
16
|
media: WorkoutMedia[];
|
|
13
17
|
is_liked_by_user: boolean;
|
|
14
18
|
start_time: number;
|
|
@@ -21,6 +25,7 @@ export interface UserWorkout {
|
|
|
21
25
|
apple_watch: boolean;
|
|
22
26
|
wearos_watch: boolean;
|
|
23
27
|
verified: boolean;
|
|
28
|
+
created_at: string;
|
|
24
29
|
updated_at: string;
|
|
25
30
|
nth_workout: number;
|
|
26
31
|
/**
|
|
@@ -34,8 +39,14 @@ export interface UserWorkout {
|
|
|
34
39
|
*/
|
|
35
40
|
include_warmup_sets: boolean;
|
|
36
41
|
is_private: boolean;
|
|
42
|
+
/**
|
|
43
|
+
* If applicable, the user ID of the coach who logged this workout
|
|
44
|
+
*/
|
|
45
|
+
logged_by_coach_id?: string;
|
|
37
46
|
biometrics?: WorkoutBiometrics;
|
|
38
47
|
is_biometrics_public: boolean;
|
|
48
|
+
trainer_program_id: string | undefined;
|
|
49
|
+
trainer_workout_template_id: string | undefined;
|
|
39
50
|
gym: UserWorkoutGym | undefined;
|
|
40
51
|
}
|
|
41
52
|
export interface UserWorkoutExercise {
|
|
@@ -56,10 +67,17 @@ export interface UserWorkoutExercise {
|
|
|
56
67
|
superset_id: number | null;
|
|
57
68
|
rest_seconds: number | null;
|
|
58
69
|
notes: string;
|
|
70
|
+
priority: number;
|
|
59
71
|
muscle_group: MuscleGroup;
|
|
60
72
|
other_muscles: MuscleGroup[];
|
|
61
73
|
exercise_type: ExerciseType;
|
|
74
|
+
equipment_category: Equipment;
|
|
75
|
+
url?: string;
|
|
76
|
+
media_type?: string;
|
|
77
|
+
custom_exercise_image_url?: string | null;
|
|
62
78
|
thumbnail_url?: string | null;
|
|
79
|
+
manual_tag?: string;
|
|
80
|
+
aka?: string;
|
|
63
81
|
/**
|
|
64
82
|
* for exercises with two dumbbells
|
|
65
83
|
*
|
|
@@ -85,6 +103,16 @@ export interface UserWorkoutExerciseSet {
|
|
|
85
103
|
duration_seconds?: number | null;
|
|
86
104
|
custom_metric?: number | null;
|
|
87
105
|
rpe?: RPE | null;
|
|
106
|
+
/**
|
|
107
|
+
* @deprecated 1.29.17 -
|
|
108
|
+
* we can only set this to `best_weight`, `best_reps`, `best_duration` or
|
|
109
|
+
* `best_distance`. sending anything else would cause older clients to crash.
|
|
110
|
+
* newer clients will ignore this field and use the `prs` field instead.
|
|
111
|
+
*/
|
|
112
|
+
personalRecords?: Array<{
|
|
113
|
+
type: 'best_weight' | 'best_reps' | 'best_duration' | 'best_distance';
|
|
114
|
+
value: number;
|
|
115
|
+
}>;
|
|
88
116
|
prs: {
|
|
89
117
|
type: SetPersonalRecordType;
|
|
90
118
|
value: number;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ExerciseType, MuscleGroup, PreviewWorkoutLike, RPE, SetPersonalRecordType, SetType, WorkoutBiometrics, WorkoutComment, WorkoutMedia } from '..';
|
|
1
|
+
import { Equipment, ExerciseType, MuscleGroup, PreviewWorkoutLike, RPE, SetPersonalRecordType, SetType, WorkoutBiometrics, WorkoutComment, WorkoutMedia } from '..';
|
|
2
2
|
export interface OwnedWorkout {
|
|
3
3
|
id: string;
|
|
4
4
|
short_id: string | null;
|
|
@@ -6,9 +6,13 @@ export interface OwnedWorkout {
|
|
|
6
6
|
name: string;
|
|
7
7
|
description?: string;
|
|
8
8
|
like_count: number;
|
|
9
|
+
/** @deprecated 2.3.4 */
|
|
10
|
+
like_images: string[];
|
|
9
11
|
preview_workout_likes: PreviewWorkoutLike[];
|
|
10
12
|
comment_count: number;
|
|
11
13
|
comments: WorkoutComment[];
|
|
14
|
+
/** @deprecated 1.28.13 */
|
|
15
|
+
image_urls?: string[];
|
|
12
16
|
media: WorkoutMedia[];
|
|
13
17
|
is_liked_by_user: boolean;
|
|
14
18
|
start_time: number;
|
|
@@ -24,10 +28,25 @@ export interface OwnedWorkout {
|
|
|
24
28
|
created_at: string;
|
|
25
29
|
updated_at: string;
|
|
26
30
|
nth_workout: number;
|
|
31
|
+
/**
|
|
32
|
+
* See https://github.com/hevyapp/hevy-backend/pull/193 to understand
|
|
33
|
+
* why we added estimated_volume_kg
|
|
34
|
+
*/
|
|
35
|
+
estimated_volume_kg: number;
|
|
36
|
+
/**
|
|
37
|
+
* Whether to include warmup sets in various calculations.
|
|
38
|
+
* https://github.com/hevyapp/hevy-shared/pull/312
|
|
39
|
+
*/
|
|
40
|
+
include_warmup_sets: boolean;
|
|
27
41
|
is_private: boolean;
|
|
42
|
+
/**
|
|
43
|
+
* If applicable, the user ID of the coach who logged this workout
|
|
44
|
+
*/
|
|
45
|
+
logged_by_coach_id?: string;
|
|
28
46
|
biometrics?: WorkoutBiometrics;
|
|
29
47
|
is_biometrics_public: boolean;
|
|
30
48
|
trainer_program_id: string | undefined;
|
|
49
|
+
trainer_workout_template_id: string | undefined;
|
|
31
50
|
gym_id: string | undefined;
|
|
32
51
|
is_home_gym: boolean;
|
|
33
52
|
}
|
|
@@ -52,10 +71,17 @@ export interface OwnedWorkoutExercise {
|
|
|
52
71
|
superset_id: number | null;
|
|
53
72
|
rest_seconds: number | null;
|
|
54
73
|
notes: string;
|
|
74
|
+
priority: number;
|
|
55
75
|
muscle_group: MuscleGroup;
|
|
56
76
|
other_muscles: MuscleGroup[];
|
|
57
77
|
exercise_type: ExerciseType;
|
|
78
|
+
equipment_category: Equipment;
|
|
79
|
+
url?: string;
|
|
80
|
+
media_type?: string;
|
|
81
|
+
custom_exercise_image_url?: string | null;
|
|
58
82
|
thumbnail_url?: string | null;
|
|
83
|
+
manual_tag?: string;
|
|
84
|
+
aka?: string;
|
|
59
85
|
/**
|
|
60
86
|
* for exercises with two dumbbells
|
|
61
87
|
*
|
|
@@ -81,6 +107,16 @@ export interface OwnedWorkoutExerciseSet {
|
|
|
81
107
|
duration_seconds?: number | null;
|
|
82
108
|
custom_metric?: number | null;
|
|
83
109
|
rpe?: RPE | null;
|
|
110
|
+
/**
|
|
111
|
+
* @deprecated 1.29.17 -
|
|
112
|
+
* we can only set this to `best_weight`, `best_reps`, `best_duration` or
|
|
113
|
+
* `best_distance`. sending anything else would cause older clients to crash.
|
|
114
|
+
* newer clients will ignore this field and use the `prs` field instead.
|
|
115
|
+
*/
|
|
116
|
+
personalRecords?: Array<{
|
|
117
|
+
type: 'best_weight' | 'best_reps' | 'best_duration' | 'best_distance';
|
|
118
|
+
value: number;
|
|
119
|
+
}>;
|
|
84
120
|
prs: {
|
|
85
121
|
type: SetPersonalRecordType;
|
|
86
122
|
value: number;
|
package/package.json
CHANGED
package/built/geography.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const distanceMBetween: (lat1: number, lon1: number, lat2: number, lon2: number) => number;
|
package/built/geography.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.distanceMBetween = void 0;
|
|
4
|
-
const haversineDistance = (lat1, lon1, lat2, lon2) => {
|
|
5
|
-
const R = 6371;
|
|
6
|
-
const dLat = ((lat2 - lat1) * Math.PI) / 180;
|
|
7
|
-
const dLon = ((lon2 - lon1) * Math.PI) / 180;
|
|
8
|
-
const a = Math.sin(dLat / 2) ** 2 +
|
|
9
|
-
Math.cos((lat1 * Math.PI) / 180) *
|
|
10
|
-
Math.cos((lat2 * Math.PI) / 180) *
|
|
11
|
-
Math.sin(dLon / 2) ** 2;
|
|
12
|
-
return R * 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
|
|
13
|
-
};
|
|
14
|
-
const distanceMBetween = (lat1, lon1, lat2, lon2) => Math.round(haversineDistance(lat1, lon1, lat2, lon2) * 1000);
|
|
15
|
-
exports.distanceMBetween = distanceMBetween;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
const geography_1 = require("../geography");
|
|
13
|
-
describe('Geography utils', () => {
|
|
14
|
-
describe('distanceMBetween', () => {
|
|
15
|
-
it('Calculates the distance between two sets of coordinates', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
16
|
-
expect((0, geography_1.distanceMBetween)(51.001, 52, 51, 52)).toBe(111);
|
|
17
|
-
expect((0, geography_1.distanceMBetween)(51.002, 52, 51, 52)).toBe(222);
|
|
18
|
-
expect((0, geography_1.distanceMBetween)(50.999, 52, 51, 52)).toBe(111);
|
|
19
|
-
expect((0, geography_1.distanceMBetween)(51.01, 52, 51, 52)).toBe(1112);
|
|
20
|
-
expect((0, geography_1.distanceMBetween)(51.04, 52, 51, 52)).toBe(4448);
|
|
21
|
-
expect((0, geography_1.distanceMBetween)(51.035, 52.035, 51, 52)).toBe(4598);
|
|
22
|
-
expect((0, geography_1.distanceMBetween)(50.965, 51.965, 51, 52)).toBe(4599);
|
|
23
|
-
}));
|
|
24
|
-
});
|
|
25
|
-
});
|