hevy-shared 1.0.1049 → 1.0.1051
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/index.d.ts +15 -4
- package/built/index.js +0 -1
- package/built/workout/index.d.ts +3 -3
- package/built/workout/index.js +3 -2
- package/built/workout/publicWorkout.d.ts +3 -1
- package/built/workout/userWorkout.d.ts +29 -1
- package/built/workout/workout.d.ts +36 -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
package/built/index.d.ts
CHANGED
|
@@ -29,7 +29,6 @@ export * from './hevyTrainer';
|
|
|
29
29
|
export * from './translations';
|
|
30
30
|
export * from './exerciseLocaleUtils';
|
|
31
31
|
export * from './getVolumeComparison';
|
|
32
|
-
export * from './geography';
|
|
33
32
|
export type WeightUnit = 'kg' | 'lbs';
|
|
34
33
|
export declare const isWeightUnit: (x: string) => x is WeightUnit;
|
|
35
34
|
export type DistanceUnit = 'kilometers' | 'miles';
|
|
@@ -303,8 +302,21 @@ export interface BackofficeExistingUserResponse {
|
|
|
303
302
|
public_api_key: string | null;
|
|
304
303
|
limited_discovery: boolean;
|
|
305
304
|
coach_trial_expire_date?: string;
|
|
306
|
-
hevy_trainer_program:
|
|
305
|
+
hevy_trainer_program: BackofficeTrainerProgram | null;
|
|
307
306
|
}
|
|
307
|
+
/**
|
|
308
|
+
* A user has at most one active Hevy Trainer program, on either the v2 schema
|
|
309
|
+
* (program → routines) or the v3 schema (program → templates). The backoffice
|
|
310
|
+
* receives whichever exists as a discriminated union keyed by `schema_version`
|
|
311
|
+
* so the front-end can render each shape.
|
|
312
|
+
*/
|
|
313
|
+
export type BackofficeTrainerProgram = {
|
|
314
|
+
schema_version: 'v2';
|
|
315
|
+
program: HevyTrainerProgram;
|
|
316
|
+
} | {
|
|
317
|
+
schema_version: 'v3';
|
|
318
|
+
program: TrainerProgramV3;
|
|
319
|
+
};
|
|
308
320
|
export interface BackofficeDeletedUserResponse {
|
|
309
321
|
state: 'deleted-account';
|
|
310
322
|
id: string;
|
|
@@ -1514,8 +1526,7 @@ type CommercialGym = {
|
|
|
1514
1526
|
name: string;
|
|
1515
1527
|
fullAddress: string;
|
|
1516
1528
|
city: string;
|
|
1517
|
-
|
|
1518
|
-
longitude: number;
|
|
1529
|
+
distanceM: number;
|
|
1519
1530
|
};
|
|
1520
1531
|
export type Gym = CommercialGym;
|
|
1521
1532
|
export interface StripePrice {
|
package/built/index.js
CHANGED
|
@@ -41,7 +41,6 @@ __exportStar(require("./hevyTrainer"), exports);
|
|
|
41
41
|
__exportStar(require("./translations"), exports);
|
|
42
42
|
__exportStar(require("./exerciseLocaleUtils"), exports);
|
|
43
43
|
__exportStar(require("./getVolumeComparison"), exports);
|
|
44
|
-
__exportStar(require("./geography"), exports);
|
|
45
44
|
const isWeightUnit = (x) => {
|
|
46
45
|
return x === 'kg' || x === 'lbs';
|
|
47
46
|
};
|
package/built/workout/index.d.ts
CHANGED
|
@@ -11,7 +11,7 @@ export interface WorkoutSync {
|
|
|
11
11
|
isMore: boolean;
|
|
12
12
|
updated_at?: string;
|
|
13
13
|
}
|
|
14
|
-
export type Workout = OwnedWorkout
|
|
15
|
-
export type WorkoutExercise = OwnedWorkoutExercise
|
|
16
|
-
export type WorkoutExerciseSet = OwnedWorkoutExerciseSet
|
|
14
|
+
export type Workout = OwnedWorkout & Partial<UserWorkout>;
|
|
15
|
+
export type WorkoutExercise = OwnedWorkoutExercise & Partial<UserWorkoutExercise>;
|
|
16
|
+
export type WorkoutExerciseSet = OwnedWorkoutExerciseSet & Partial<UserWorkoutExerciseSet>;
|
|
17
17
|
export declare function isOwnedWorkout(workout: OwnedWorkout | UserWorkout): workout is OwnedWorkout;
|
package/built/workout/index.js
CHANGED
|
@@ -20,7 +20,8 @@ __exportStar(require("./userWorkout"), exports);
|
|
|
20
20
|
__exportStar(require("./publicWorkout"), exports);
|
|
21
21
|
__exportStar(require("./normalizedWorkout"), exports);
|
|
22
22
|
__exportStar(require("./postWorkoutRequest"), exports);
|
|
23
|
-
//
|
|
23
|
+
// Stub
|
|
24
24
|
function isOwnedWorkout(workout) {
|
|
25
|
-
|
|
25
|
+
void workout;
|
|
26
|
+
return true;
|
|
26
27
|
}
|
|
@@ -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,7 +28,21 @@ 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;
|
|
@@ -53,10 +71,17 @@ export interface OwnedWorkoutExercise {
|
|
|
53
71
|
superset_id: number | null;
|
|
54
72
|
rest_seconds: number | null;
|
|
55
73
|
notes: string;
|
|
74
|
+
priority: number;
|
|
56
75
|
muscle_group: MuscleGroup;
|
|
57
76
|
other_muscles: MuscleGroup[];
|
|
58
77
|
exercise_type: ExerciseType;
|
|
78
|
+
equipment_category: Equipment;
|
|
79
|
+
url?: string;
|
|
80
|
+
media_type?: string;
|
|
81
|
+
custom_exercise_image_url?: string | null;
|
|
59
82
|
thumbnail_url?: string | null;
|
|
83
|
+
manual_tag?: string;
|
|
84
|
+
aka?: string;
|
|
60
85
|
/**
|
|
61
86
|
* for exercises with two dumbbells
|
|
62
87
|
*
|
|
@@ -82,6 +107,16 @@ export interface OwnedWorkoutExerciseSet {
|
|
|
82
107
|
duration_seconds?: number | null;
|
|
83
108
|
custom_metric?: number | null;
|
|
84
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
|
+
}>;
|
|
85
120
|
prs: {
|
|
86
121
|
type: SetPersonalRecordType;
|
|
87
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
|
-
});
|