Compare commits
	
		
			46 Commits
		
	
	
		
			kat/add-id
			...
			8ed177b0f3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8ed177b0f3 | |||
| 976cc66ccb | |||
| af461fff00 | |||
| 7a39b4ca60 | |||
| 9befbe3833 | |||
| 68a4c064f3 | |||
| 54fd741670 | |||
| 2f9e630de4 | |||
| 5efd8ef8e5 | |||
| 6ad3d449d8 | |||
| 8fe20d1c41 | |||
| e151f39582 | |||
| f136ddb9ca | |||
| 5d05614e07 | |||
| c4c3ccde00 | |||
| e137ce8ad1 | |||
| bd5bebb747 | |||
| 034facebf3 | |||
| ac1fceb648 | |||
| fd87ade629 | |||
| 1fab007654 | |||
| cd2cdb475a | |||
| c3c74379fb | |||
| da21627f15 | |||
| 8fabfd67cf | |||
| e6960038f2 | |||
| b6ec7ed39d | |||
| 545ba638c2 | |||
| 94e4e55558 | |||
| 2536f5db6b | |||
| ffd0814a98 | |||
| 55bfe42484 | |||
| dabb0d1d9c | |||
| a538c1d81c | |||
| 872bce3adb | |||
| 12798e368c | |||
| a3d6e6e19e | |||
| f7a6e393e7 | |||
| ee11e506ed | |||
| 90ec47848b | |||
| 21acb5219d | |||
| 087d511efc | |||
| 7cc0dca821 | |||
| f826121aa3 | |||
| 2aadb8b49b | |||
| 5468b7ccda | 
							
								
								
									
										647
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										647
									
								
								src/index.tsx
									
									
									
									
									
								
							| @@ -117,6 +117,11 @@ export type BucketSetInputGql = { | ||||
|   feature: Scalars["String"]["input"]; | ||||
| }; | ||||
|  | ||||
| export enum ClientUploadStatusEnum { | ||||
|   UploadDisabled = "UPLOAD_DISABLED", | ||||
|   UploadEnabled = "UPLOAD_ENABLED", | ||||
| } | ||||
|  | ||||
| export type CreateBucketSetInput = { | ||||
|   buckets: Array<BucketInputGql>; | ||||
|   feature: Scalars["String"]["input"]; | ||||
| @@ -150,6 +155,11 @@ export type DateRangeFilter = { | ||||
|   lessThanInclusive?: Scalars["Boolean"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type DatetimeOrdering = { | ||||
|   descending?: Scalars["Boolean"]["input"]; | ||||
|   startingAt?: InputMaybe<Scalars["DateTime"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type DatetimeRangeAggregationInput = { | ||||
|   endDatetime?: InputMaybe<Scalars["DateTime"]["input"]>; | ||||
|   feature?: Scalars["String"]["input"]; | ||||
| @@ -157,11 +167,6 @@ export type DatetimeRangeAggregationInput = { | ||||
|   startDatetime?: InputMaybe<Scalars["DateTime"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type DatetimeShotOrdering = { | ||||
|   descending?: Scalars["Boolean"]["input"]; | ||||
|   startingAt?: InputMaybe<Scalars["DateTime"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type DeployedConfigGql = { | ||||
|   __typename?: "DeployedConfigGQL"; | ||||
|   allowNewUsers: Scalars["Boolean"]["output"]; | ||||
| @@ -181,12 +186,29 @@ export type DoesNotOwnShotErrOtherErrorNeedsNote = | ||||
|   | DoesNotOwnShotErr | ||||
|   | OtherErrorNeedsNote; | ||||
|  | ||||
| export type EditShotReturn = { | ||||
|   __typename?: "EditShotReturn"; | ||||
|   error?: Maybe<DoesNotOwnShotErr>; | ||||
|   shot?: Maybe<ShotGql>; | ||||
| }; | ||||
|  | ||||
| export type EditUserInputGql = { | ||||
|   fargoRating?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   username?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   videosPrivateByDefault?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type EditableShotFieldInputGql = { | ||||
|   backcut?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   excludeFromStats?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   intendedPocketType?: InputMaybe<PocketEnum>; | ||||
|   make?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   notes?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   shotDirection?: InputMaybe<ShotDirectionEnum>; | ||||
|   spinType?: InputMaybe<SpinTypeEnum>; | ||||
|   targetPocketAngleDirection?: InputMaybe<ShotDirectionEnum>; | ||||
| }; | ||||
|  | ||||
| export type EnumAggregation = { | ||||
|   feature: Scalars["String"]["input"]; | ||||
| }; | ||||
| @@ -1873,6 +1895,11 @@ export type FilterInput = | ||||
|       videoId: Array<Scalars["Int"]["input"]>; | ||||
|     }; | ||||
|  | ||||
| export type FloatOrdering = { | ||||
|   descending?: Scalars["Boolean"]["input"]; | ||||
|   startingAt?: InputMaybe<Scalars["Float"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type FloatRangeFilter = { | ||||
|   greaterThan?: InputMaybe<Scalars["Float"]["input"]>; | ||||
|   greaterThanEqualTo?: InputMaybe<Scalars["Float"]["input"]>; | ||||
| @@ -1882,11 +1909,6 @@ export type FloatRangeFilter = { | ||||
|   lessThanInclusive?: Scalars["Boolean"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type FloatShotOrdering = { | ||||
|   descending?: Scalars["Boolean"]["input"]; | ||||
|   startingAt?: InputMaybe<Scalars["Float"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type GetProfileUploadLinkErrors = { | ||||
|   __typename?: "GetProfileUploadLinkErrors"; | ||||
|   error: TooManyProfileImageUploadsErr; | ||||
| @@ -1897,6 +1919,17 @@ export type GetProfileUploadLinkReturn = { | ||||
|   value: UploadLinkGetProfileUploadLinkErrors; | ||||
| }; | ||||
|  | ||||
| export type GetRunsOrdering = { | ||||
|   orderings: Array<RunsOrderingComponent>; | ||||
| }; | ||||
|  | ||||
| export type GetRunsResult = { | ||||
|   __typename?: "GetRunsResult"; | ||||
|   count?: Maybe<Scalars["Int"]["output"]>; | ||||
|   runIds: Array<Scalars["Int"]["output"]>; | ||||
|   runs: Array<RunGql>; | ||||
| }; | ||||
|  | ||||
| export type GetShotsOrdering = { | ||||
|   orderings: Array<ShotsOrderingComponent>; | ||||
| }; | ||||
| @@ -1959,17 +1992,17 @@ export type InitUploadAlreadyCompletedErr = { | ||||
|   segmentType: StreamSegmentTypeEnum; | ||||
| }; | ||||
|  | ||||
| export type IntOrdering = { | ||||
|   descending?: Scalars["Boolean"]["input"]; | ||||
|   startingAt?: InputMaybe<Scalars["Int"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type IntPoint2D = { | ||||
|   __typename?: "IntPoint2D"; | ||||
|   x: Scalars["Int"]["output"]; | ||||
|   y: Scalars["Int"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type IntShotOrdering = { | ||||
|   descending?: Scalars["Boolean"]["input"]; | ||||
|   startingAt?: InputMaybe<Scalars["Int"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type MakePercentageIntervalGql = { | ||||
|   __typename?: "MakePercentageIntervalGQL"; | ||||
|   elapsedTime: Scalars["Float"]["output"]; | ||||
| @@ -1979,11 +2012,21 @@ export type MakePercentageIntervalGql = { | ||||
| export type MedalGql = { | ||||
|   __typename?: "MedalGQL"; | ||||
|   count: Scalars["Int"]["output"]; | ||||
|   nickname?: Maybe<Scalars["String"]["output"]>; | ||||
| }; | ||||
|  | ||||
| export type MedalScope = | ||||
|   | { interval: TimeInterval; videoId?: never } | ||||
|   | { interval?: never; videoId: Scalars["Int"]["input"] }; | ||||
|   | { | ||||
|       datetimeRange: DatetimeRangeAggregationInput; | ||||
|       interval?: never; | ||||
|       videoId?: never; | ||||
|     } /** @deprecated NO LONGER SUPPORTED, USE DATETIME_RANGE */ | ||||
|   | { datetimeRange?: never; interval: TimeInterval; videoId?: never } | ||||
|   | { | ||||
|       datetimeRange?: never; | ||||
|       interval?: never; | ||||
|       videoId: Scalars["Int"]["input"]; | ||||
|     }; | ||||
|  | ||||
| export type MustHaveSetForUploadLinkErr = { | ||||
|   __typename?: "MustHaveSetForUploadLinkErr"; | ||||
| @@ -2008,6 +2051,7 @@ export type Mutation = { | ||||
|   createUploadStream: CreateUploadStreamReturn; | ||||
|   deleteVideo: Scalars["Boolean"]["output"]; | ||||
|   editProfileImageUri: UserGql; | ||||
|   editShot: EditShotReturn; | ||||
|   editUploadStream: Scalars["Boolean"]["output"]; | ||||
|   editUser: UserGql; | ||||
|   findPrerecordTableLayout?: Maybe<HomographyInfoGql>; | ||||
| @@ -2043,6 +2087,11 @@ export type MutationEditProfileImageUriArgs = { | ||||
|   profileImageUri: Scalars["String"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type MutationEditShotArgs = { | ||||
|   fieldsToEdit: EditableShotFieldInputGql; | ||||
|   shotId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type MutationEditUploadStreamArgs = { | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
|   videoMetadata: VideoMetadataInput; | ||||
| @@ -2180,6 +2229,7 @@ export type Query = { | ||||
|   getMedals: RequestedMedalsGql; | ||||
|   getOrderedShots: GetShotsResult; | ||||
|   getPlayTime: UserPlayTimeGql; | ||||
|   getRuns: GetRunsResult; | ||||
|   getShotAnnotationTypes: Array<ShotAnnotationTypeGql>; | ||||
|   getShots: Array<ShotGql>; | ||||
|   getShotsByIds: Array<ShotGql>; | ||||
| @@ -2210,6 +2260,7 @@ export type QueryGetBucketSetArgs = { | ||||
| export type QueryGetFeedVideosArgs = { | ||||
|   after?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   filters?: InputMaybe<VideoFilterInput>; | ||||
|   includeCallersVideos?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| @@ -2231,6 +2282,14 @@ export type QueryGetPlayTimeArgs = { | ||||
|   userId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type QueryGetRunsArgs = { | ||||
|   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||
|   filterInput: RunFilterInput; | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
|   runIds?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||
|   runsOrdering?: InputMaybe<GetRunsOrdering>; | ||||
| }; | ||||
|  | ||||
| export type QueryGetShotAnnotationTypesArgs = { | ||||
|   errorTypes?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }; | ||||
| @@ -2298,17 +2357,11 @@ export type QueryWaitForArgs = { | ||||
|  | ||||
| export type RequestedMedalsGql = { | ||||
|   __typename?: "RequestedMedalsGQL"; | ||||
|   dayStreak2?: Maybe<MedalGql>; | ||||
|   dayStreak3?: Maybe<MedalGql>; | ||||
|   dayStreak4?: Maybe<MedalGql>; | ||||
|   dayStreak5?: Maybe<MedalGql>; | ||||
|   dayStreak6?: Maybe<MedalGql>; | ||||
|   dayStreak7?: Maybe<MedalGql>; | ||||
|   dayStreak14?: Maybe<MedalGql>; | ||||
|   dayStreak21?: Maybe<MedalGql>; | ||||
|   dayStreak30?: Maybe<MedalGql>; | ||||
|   dayStreak60?: Maybe<MedalGql>; | ||||
|   dayStreak90?: Maybe<MedalGql>; | ||||
|   dailyMakes50?: Maybe<MedalGql>; | ||||
|   dailyMakes100?: Maybe<MedalGql>; | ||||
|   dailyMakes150?: Maybe<MedalGql>; | ||||
|   dailyMakes200?: Maybe<MedalGql>; | ||||
|   dailyMakes250?: Maybe<MedalGql>; | ||||
|   distanceOver66?: Maybe<MedalGql>; | ||||
|   distanceOver78?: Maybe<MedalGql>; | ||||
|   distanceOver90?: Maybe<MedalGql>; | ||||
| @@ -2322,18 +2375,53 @@ export type RequestedMedalsGql = { | ||||
|   runLength30?: Maybe<MedalGql>; | ||||
|   runLength40?: Maybe<MedalGql>; | ||||
|   runLength50?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes25?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes50?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes75?: Maybe<MedalGql>; | ||||
|   totalMakes100?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes200?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes300?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes400?: Maybe<MedalGql>; | ||||
|   totalMakes500?: Maybe<MedalGql>; | ||||
|   /** @deprecated no longer supported */ | ||||
|   totalMakes750?: Maybe<MedalGql>; | ||||
|   totalMakes1000?: Maybe<MedalGql>; | ||||
|   totalMakes5000?: Maybe<MedalGql>; | ||||
|   totalMakes10000?: Maybe<MedalGql>; | ||||
| }; | ||||
|  | ||||
| export type RunFilterInput = { | ||||
|   andFilters?: InputMaybe<Array<RunFilterInput>>; | ||||
|   createdAt?: InputMaybe<DateRangeFilter>; | ||||
|   notFilter?: InputMaybe<RunFilterInput>; | ||||
|   orFilters?: InputMaybe<Array<RunFilterInput>>; | ||||
|   runLength?: InputMaybe<FloatRangeFilter>; | ||||
|   tableSize?: InputMaybe<FloatRangeFilter>; | ||||
|   userId?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||
|   username?: InputMaybe<Array<Scalars["String"]["input"]>>; | ||||
|   videoId?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||
| }; | ||||
|  | ||||
| export type RunGql = { | ||||
|   __typename?: "RunGQL"; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   runLength: Scalars["Int"]["output"]; | ||||
|   shots: Array<ShotGql>; | ||||
|   userId: Scalars["Int"]["output"]; | ||||
|   videoId: Scalars["Int"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type RunsOrderingComponent = | ||||
|   | { runLength: IntOrdering; videoCreation?: never; videoId?: never } | ||||
|   | { runLength?: never; videoCreation: DatetimeOrdering; videoId?: never } | ||||
|   | { runLength?: never; videoCreation?: never; videoId: IntOrdering }; | ||||
|  | ||||
| export type SegmentAlreadyUploadedErr = { | ||||
|   __typename?: "SegmentAlreadyUploadedErr"; | ||||
|   segmentId: Scalars["Int"]["output"]; | ||||
| @@ -2413,39 +2501,52 @@ export type ShotGql = { | ||||
|  | ||||
| export type ShotsOrderingComponent = | ||||
|   | { | ||||
|       marginOfError: FloatShotOrdering; | ||||
|       difficulty: FloatOrdering; | ||||
|       marginOfError?: never; | ||||
|       runLength?: never; | ||||
|       startFrame?: never; | ||||
|       videoCreation?: never; | ||||
|       videoId?: never; | ||||
|     } | ||||
|   | { | ||||
|       marginOfError?: never; | ||||
|       runLength: IntShotOrdering; | ||||
|       difficulty?: never; | ||||
|       marginOfError: FloatOrdering; | ||||
|       runLength?: never; | ||||
|       startFrame?: never; | ||||
|       videoCreation?: never; | ||||
|       videoId?: never; | ||||
|     } | ||||
|   | { | ||||
|       difficulty?: never; | ||||
|       marginOfError?: never; | ||||
|       runLength?: never; | ||||
|       startFrame: IntShotOrdering; | ||||
|       runLength: IntOrdering; | ||||
|       startFrame?: never; | ||||
|       videoCreation?: never; | ||||
|       videoId?: never; | ||||
|     } | ||||
|   | { | ||||
|       difficulty?: never; | ||||
|       marginOfError?: never; | ||||
|       runLength?: never; | ||||
|       startFrame?: never; | ||||
|       videoCreation: DatetimeShotOrdering; | ||||
|       startFrame: IntOrdering; | ||||
|       videoCreation?: never; | ||||
|       videoId?: never; | ||||
|     } | ||||
|   | { | ||||
|       difficulty?: never; | ||||
|       marginOfError?: never; | ||||
|       runLength?: never; | ||||
|       startFrame?: never; | ||||
|       videoCreation: DatetimeOrdering; | ||||
|       videoId?: never; | ||||
|     } | ||||
|   | { | ||||
|       difficulty?: never; | ||||
|       marginOfError?: never; | ||||
|       runLength?: never; | ||||
|       startFrame?: never; | ||||
|       videoCreation?: never; | ||||
|       videoId: IntShotOrdering; | ||||
|       videoId: IntOrdering; | ||||
|     }; | ||||
|  | ||||
| export type SpinTypeCountsGql = { | ||||
| @@ -2555,6 +2656,7 @@ export type UploadSegmentGql = { | ||||
|  | ||||
| export type UploadStreamGql = { | ||||
|   __typename?: "UploadStreamGQL"; | ||||
|   clientUploadStatus?: Maybe<ClientUploadStatusEnum>; | ||||
|   createdAt: Scalars["DateTime"]["output"]; | ||||
|   errors: Array<StreamErrorGql>; | ||||
|   id: Scalars["ID"]["output"]; | ||||
| @@ -2609,6 +2711,7 @@ export type UserRelationshipsResult = { | ||||
|  | ||||
| export type VideoFilterInput = { | ||||
|   createdAt?: InputMaybe<DateRangeFilter>; | ||||
|   excludeVideosWithNoShots?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   isStreamCompleted?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   requireCursorCompletion?: Scalars["Boolean"]["input"]; | ||||
| }; | ||||
| @@ -2648,6 +2751,7 @@ export type VideoHistoryGql = { | ||||
| }; | ||||
|  | ||||
| export type VideoMetadataInput = { | ||||
|   clientUploadStatus?: InputMaybe<ClientUploadStatusEnum>; | ||||
|   endStream?: Scalars["Boolean"]["input"]; | ||||
|   endTime?: InputMaybe<Scalars["DateTime"]["input"]>; | ||||
|   framesPerSecond?: InputMaybe<Scalars["Float"]["input"]>; | ||||
| @@ -2778,9 +2882,15 @@ export type GetFeedQuery = { | ||||
|       updatedAt?: any | null; | ||||
|       startTime?: any | null; | ||||
|       endTime?: any | null; | ||||
|       private: boolean; | ||||
|       elapsedTime?: number | null; | ||||
|       tableSize: number; | ||||
|       owner?: { __typename?: "UserGQL"; username: string } | null; | ||||
|       owner?: { | ||||
|         __typename?: "UserGQL"; | ||||
|         id: number; | ||||
|         username: string; | ||||
|         profileImageUri?: string | null; | ||||
|       } | null; | ||||
|       stream?: { | ||||
|         __typename?: "UploadStreamGQL"; | ||||
|         id: string; | ||||
| @@ -2791,6 +2901,19 @@ export type GetFeedQuery = { | ||||
|         name: string; | ||||
|         tagClasses: Array<{ __typename?: "VideoTagClass"; name: string }>; | ||||
|       }>; | ||||
|       currentProcessing?: { | ||||
|         __typename?: "VideoProcessingGQL"; | ||||
|         id: number; | ||||
|         status: ProcessingStatusEnum; | ||||
|         errors: Array<{ | ||||
|           __typename?: "VideoProcessingErrorGQL"; | ||||
|           message: string; | ||||
|         }>; | ||||
|         statuses: Array<{ | ||||
|           __typename?: "VideoProcessingStatusGQL"; | ||||
|           status: ProcessingStatusEnum; | ||||
|         }>; | ||||
|       } | null; | ||||
|     }>; | ||||
|     pageInfo: { | ||||
|       __typename?: "PageInfoGQL"; | ||||
| @@ -2847,6 +2970,7 @@ export type GetVideoFeedQueryVariables = Exact<{ | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
|   after?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   filters?: InputMaybe<VideoFilterInput>; | ||||
|   includeCallersVideos?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type GetVideoFeedQuery = { | ||||
| @@ -2920,6 +3044,134 @@ export type GetVideoMakePercentageIntervalsQuery = { | ||||
|   }>; | ||||
| }; | ||||
|  | ||||
| export type MedalFieldsFragment = { | ||||
|   __typename?: "MedalGQL"; | ||||
|   count: number; | ||||
|   nickname?: string | null; | ||||
| }; | ||||
|  | ||||
| export type GetMedalsQueryVariables = Exact<{ | ||||
|   scope: MedalScope; | ||||
|   userId?: InputMaybe<Scalars["Int"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type GetMedalsQuery = { | ||||
|   __typename?: "Query"; | ||||
|   getMedals: { | ||||
|     __typename?: "RequestedMedalsGQL"; | ||||
|     distanceOver78?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     distanceOver90?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength3?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength5?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength8?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength10?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength15?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength20?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength25?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength30?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength40?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     runLength50?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     totalMakes100?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     totalMakes500?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     totalMakes1000?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     totalMakes5000?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     totalMakes10000?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     dailyMakes50?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     dailyMakes100?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     dailyMakes150?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     dailyMakes200?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|     dailyMakes250?: { | ||||
|       __typename?: "MedalGQL"; | ||||
|       count: number; | ||||
|       nickname?: string | null; | ||||
|     } | null; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetSerializedShotPathsQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
| }>; | ||||
| @@ -3064,6 +3316,7 @@ export type GetShotsWithMetadataFilterResultQuery = { | ||||
|         targetPocketAngleDirection?: ShotDirectionEnum | null; | ||||
|         marginOfErrorInDegrees?: number | null; | ||||
|         intendedPocketType?: PocketEnum | null; | ||||
|         difficulty?: number | null; | ||||
|       } | null; | ||||
|       pocketingIntentionInfo?: { | ||||
|         __typename?: "PocketingIntentionInfoGQL"; | ||||
| @@ -3130,6 +3383,7 @@ export type GetShotsWithMetadataQuery = { | ||||
|         targetPocketAngleDirection?: ShotDirectionEnum | null; | ||||
|         marginOfErrorInDegrees?: number | null; | ||||
|         intendedPocketType?: PocketEnum | null; | ||||
|         difficulty?: number | null; | ||||
|       } | null; | ||||
|       pocketingIntentionInfo?: { | ||||
|         __typename?: "PocketingIntentionInfoGQL"; | ||||
| @@ -3189,6 +3443,7 @@ export type GetShotsByIdsQuery = { | ||||
|       targetPocketAngleDirection?: ShotDirectionEnum | null; | ||||
|       marginOfErrorInDegrees?: number | null; | ||||
|       intendedPocketType?: PocketEnum | null; | ||||
|       difficulty?: number | null; | ||||
|     } | null; | ||||
|     pocketingIntentionInfo?: { | ||||
|       __typename?: "PocketingIntentionInfoGQL"; | ||||
| @@ -3237,6 +3492,7 @@ export type ShotWithAllFeaturesFragment = { | ||||
|     targetPocketAngleDirection?: ShotDirectionEnum | null; | ||||
|     marginOfErrorInDegrees?: number | null; | ||||
|     intendedPocketType?: PocketEnum | null; | ||||
|     difficulty?: number | null; | ||||
|   } | null; | ||||
|   pocketingIntentionInfo?: { | ||||
|     __typename?: "PocketingIntentionInfoGQL"; | ||||
| @@ -3256,6 +3512,74 @@ export type ShotWithAllFeaturesFragment = { | ||||
|   }>; | ||||
| }; | ||||
|  | ||||
| export type EditShotMutationVariables = Exact<{ | ||||
|   shotId: Scalars["Int"]["input"]; | ||||
|   fieldsToEdit: EditableShotFieldInputGql; | ||||
| }>; | ||||
|  | ||||
| export type EditShotMutation = { | ||||
|   __typename?: "Mutation"; | ||||
|   editShot: { | ||||
|     __typename?: "EditShotReturn"; | ||||
|     error?: { | ||||
|       __typename?: "DoesNotOwnShotErr"; | ||||
|       shotId: number; | ||||
|       msg?: string | null; | ||||
|     } | null; | ||||
|     shot?: { | ||||
|       __typename?: "ShotGQL"; | ||||
|       id: number; | ||||
|       videoId: number; | ||||
|       startFrame: number; | ||||
|       endFrame: number; | ||||
|       startTime: number; | ||||
|       endTime: number; | ||||
|       falsePositiveScore?: number | null; | ||||
|       createdAt?: any | null; | ||||
|       updatedAt?: any | null; | ||||
|       user?: { __typename?: "UserGQL"; id: number } | null; | ||||
|       cueObjectFeatures?: { | ||||
|         __typename?: "CueObjectFeaturesGQL"; | ||||
|         cueObjectDistance?: number | null; | ||||
|         cueObjectAngle?: number | null; | ||||
|         cueBallSpeed?: number | null; | ||||
|         shotDirection?: ShotDirectionEnum | null; | ||||
|         spinType?: SpinTypeEnum | null; | ||||
|       } | null; | ||||
|       pocketingIntentionFeatures?: { | ||||
|         __typename?: "PocketingIntentionFeaturesGQL"; | ||||
|         make?: boolean | null; | ||||
|         targetPocketDistance?: number | null; | ||||
|         targetPocketAngle?: number | null; | ||||
|         targetPocketAngleDirection?: ShotDirectionEnum | null; | ||||
|         marginOfErrorInDegrees?: number | null; | ||||
|         intendedPocketType?: PocketEnum | null; | ||||
|         difficulty?: number | null; | ||||
|       } | null; | ||||
|       pocketingIntentionInfo?: { | ||||
|         __typename?: "PocketingIntentionInfoGQL"; | ||||
|         ballId: number; | ||||
|         pocketId: PocketIdentifier; | ||||
|         pathMetadataIndex: number; | ||||
|       } | null; | ||||
|       serializedShotPaths?: { | ||||
|         __typename?: "SerializedShotPathsGQL"; | ||||
|         b64EncodedBuffer?: string | null; | ||||
|       } | null; | ||||
|       annotations: Array<{ | ||||
|         __typename?: "ShotAnnotationGQL"; | ||||
|         shotId: number; | ||||
|         notes: string; | ||||
|         type: { | ||||
|           __typename?: "ShotAnnotationTypeGQL"; | ||||
|           id: number; | ||||
|           name: string; | ||||
|         }; | ||||
|       }>; | ||||
|     } | null; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetProfileImageUploadLinkMutationVariables = Exact<{ | ||||
|   fileExt?: InputMaybe<Scalars["String"]["input"]>; | ||||
| }>; | ||||
| @@ -3322,6 +3646,7 @@ export type GetLoggedInUserQuery = { | ||||
|  | ||||
| export type GetUserPlayTimeQueryVariables = Exact<{ | ||||
|   userId: Scalars["Int"]["input"]; | ||||
|   filters?: InputMaybe<VideoFilterInput>; | ||||
| }>; | ||||
|  | ||||
| export type GetUserPlayTimeQuery = { | ||||
| @@ -3478,6 +3803,7 @@ export type GetStreamMonitoringDetailsQuery = { | ||||
|     elapsedTime?: number | null; | ||||
|     currentHomography?: { | ||||
|       __typename?: "HomographyInfoGQL"; | ||||
|       id: number; | ||||
|       frameIndex: number; | ||||
|       crop: { | ||||
|         __typename?: "BoundingBoxGQL"; | ||||
| @@ -3541,6 +3867,7 @@ export type GetVideoUpdatePageDetailsQuery = { | ||||
|     makePercentage: number; | ||||
|     elapsedTime?: number | null; | ||||
|     tableSize: number; | ||||
|     private: boolean; | ||||
|     tags: Array<{ | ||||
|       __typename?: "VideoTag"; | ||||
|       name: string; | ||||
| @@ -3580,6 +3907,7 @@ export type GetVideoDetailsQuery = { | ||||
|     createdAt?: any | null; | ||||
|     updatedAt?: any | null; | ||||
|     tableSize: number; | ||||
|     private: boolean; | ||||
|     owner?: { | ||||
|       __typename?: "UserGQL"; | ||||
|       id: number; | ||||
| @@ -3693,6 +4021,7 @@ export type GetVideoQuery = { | ||||
|     } | null; | ||||
|     homographyHistory: Array<{ | ||||
|       __typename?: "HomographyInfoGQL"; | ||||
|       id: number; | ||||
|       frameIndex: number; | ||||
|       crop: { | ||||
|         __typename?: "BoundingBoxGQL"; | ||||
| @@ -3903,6 +4232,7 @@ export type FindPrerecordTableLayoutMutation = { | ||||
|   __typename?: "Mutation"; | ||||
|   findPrerecordTableLayout?: { | ||||
|     __typename?: "HomographyInfoGQL"; | ||||
|     id: number; | ||||
|     frameIndex: number; | ||||
|     crop: { | ||||
|       __typename?: "BoundingBoxGQL"; | ||||
| @@ -3932,6 +4262,7 @@ export type FindPrerecordTableLayoutMutation = { | ||||
|  | ||||
| export type HomographyInfoFragment = { | ||||
|   __typename?: "HomographyInfoGQL"; | ||||
|   id: number; | ||||
|   frameIndex: number; | ||||
|   crop: { | ||||
|     __typename?: "BoundingBoxGQL"; | ||||
| @@ -4173,6 +4504,12 @@ export const VideoCardFieldsFragmentDoc = gql` | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export const MedalFieldsFragmentDoc = gql` | ||||
|   fragment MedalFields on MedalGQL { | ||||
|     count | ||||
|     nickname | ||||
|   } | ||||
| `; | ||||
| export const ShotWithAllFeaturesFragmentDoc = gql` | ||||
|   fragment ShotWithAllFeatures on ShotGQL { | ||||
|     id | ||||
| @@ -4201,6 +4538,7 @@ export const ShotWithAllFeaturesFragmentDoc = gql` | ||||
|       targetPocketAngleDirection | ||||
|       marginOfErrorInDegrees | ||||
|       intendedPocketType | ||||
|       difficulty | ||||
|     } | ||||
|     pocketingIntentionInfo { | ||||
|       ballId | ||||
| @@ -4293,6 +4631,7 @@ export const VideoDurationDataFragmentDoc = gql` | ||||
| `; | ||||
| export const HomographyInfoFragmentDoc = gql` | ||||
|   fragment HomographyInfo on HomographyInfoGQL { | ||||
|     id | ||||
|     frameIndex | ||||
|     crop { | ||||
|       left | ||||
| @@ -4498,32 +4837,7 @@ export const GetFeedDocument = gql` | ||||
|   ) { | ||||
|     getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|       videos { | ||||
|         id | ||||
|         owner { | ||||
|           username | ||||
|         } | ||||
|         name | ||||
|         screenshotUri | ||||
|         totalShotsMade | ||||
|         totalShots | ||||
|         makePercentage | ||||
|         createdAt | ||||
|         updatedAt | ||||
|         startTime | ||||
|         endTime | ||||
|         elapsedTime | ||||
|         screenshotUri | ||||
|         stream { | ||||
|           id | ||||
|           isCompleted | ||||
|         } | ||||
|         tableSize | ||||
|         tags { | ||||
|           tagClasses { | ||||
|             name | ||||
|           } | ||||
|           name | ||||
|         } | ||||
|         ...VideoCardFields | ||||
|       } | ||||
|       pageInfo { | ||||
|         hasNextPage | ||||
| @@ -4531,6 +4845,7 @@ export const GetFeedDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${VideoCardFieldsFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -4598,8 +4913,14 @@ export const GetVideoFeedDocument = gql` | ||||
|     $limit: Int! = 5 | ||||
|     $after: String = null | ||||
|     $filters: VideoFilterInput = null | ||||
|     $includeCallersVideos: Boolean = null | ||||
|   ) { | ||||
|     getFeedVideos( | ||||
|       limit: $limit | ||||
|       after: $after | ||||
|       filters: $filters | ||||
|       includeCallersVideos: $includeCallersVideos | ||||
|     ) { | ||||
|     getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|       videos { | ||||
|         ...VideoCardFields | ||||
|       } | ||||
| @@ -4627,6 +4948,7 @@ export const GetVideoFeedDocument = gql` | ||||
|  *      limit: // value for 'limit' | ||||
|  *      after: // value for 'after' | ||||
|  *      filters: // value for 'filters' | ||||
|  *      includeCallersVideos: // value for 'includeCallersVideos' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| @@ -4760,6 +5082,141 @@ export type GetVideoMakePercentageIntervalsQueryResult = Apollo.QueryResult< | ||||
|   GetVideoMakePercentageIntervalsQuery, | ||||
|   GetVideoMakePercentageIntervalsQueryVariables | ||||
| >; | ||||
| export const GetMedalsDocument = gql` | ||||
|   query getMedals($scope: MedalScope!, $userId: Int) { | ||||
|     getMedals(scope: $scope, userId: $userId) { | ||||
|       distanceOver78 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       distanceOver90 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength3 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength5 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength8 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength10 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength15 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength20 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength25 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength30 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength40 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       runLength50 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       totalMakes100 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       totalMakes500 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       totalMakes1000 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       totalMakes5000 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       totalMakes10000 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       dailyMakes50 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       dailyMakes100 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       dailyMakes150 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       dailyMakes200 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|       dailyMakes250 { | ||||
|         ...MedalFields | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${MedalFieldsFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
|  * __useGetMedalsQuery__ | ||||
|  * | ||||
|  * To run a query within a React component, call `useGetMedalsQuery` and pass it any options that fit your needs. | ||||
|  * When your component renders, `useGetMedalsQuery` returns an object from Apollo Client that contains loading, error, and data properties | ||||
|  * you can use to render your UI. | ||||
|  * | ||||
|  * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options; | ||||
|  * | ||||
|  * @example | ||||
|  * const { data, loading, error } = useGetMedalsQuery({ | ||||
|  *   variables: { | ||||
|  *      scope: // value for 'scope' | ||||
|  *      userId: // value for 'userId' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useGetMedalsQuery( | ||||
|   baseOptions: Apollo.QueryHookOptions<GetMedalsQuery, GetMedalsQueryVariables>, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useQuery<GetMedalsQuery, GetMedalsQueryVariables>( | ||||
|     GetMedalsDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export function useGetMedalsLazyQuery( | ||||
|   baseOptions?: Apollo.LazyQueryHookOptions< | ||||
|     GetMedalsQuery, | ||||
|     GetMedalsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useLazyQuery<GetMedalsQuery, GetMedalsQueryVariables>( | ||||
|     GetMedalsDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export function useGetMedalsSuspenseQuery( | ||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||
|     GetMedalsQuery, | ||||
|     GetMedalsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useSuspenseQuery<GetMedalsQuery, GetMedalsQueryVariables>( | ||||
|     GetMedalsDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export type GetMedalsQueryHookResult = ReturnType<typeof useGetMedalsQuery>; | ||||
| export type GetMedalsLazyQueryHookResult = ReturnType< | ||||
|   typeof useGetMedalsLazyQuery | ||||
| >; | ||||
| export type GetMedalsSuspenseQueryHookResult = ReturnType< | ||||
|   typeof useGetMedalsSuspenseQuery | ||||
| >; | ||||
| export type GetMedalsQueryResult = Apollo.QueryResult< | ||||
|   GetMedalsQuery, | ||||
|   GetMedalsQueryVariables | ||||
| >; | ||||
| export const GetSerializedShotPathsDocument = gql` | ||||
|   query GetSerializedShotPaths($filterInput: FilterInput!) { | ||||
|     getShots(filterInput: $filterInput) { | ||||
| @@ -5418,6 +5875,61 @@ export type GetShotsByIdsQueryResult = Apollo.QueryResult< | ||||
|   GetShotsByIdsQuery, | ||||
|   GetShotsByIdsQueryVariables | ||||
| >; | ||||
| export const EditShotDocument = gql` | ||||
|   mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { | ||||
|     editShot(shotId: $shotId, fieldsToEdit: $fieldsToEdit) { | ||||
|       error { | ||||
|         shotId | ||||
|         msg | ||||
|       } | ||||
|       shot { | ||||
|         ...ShotWithAllFeatures | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${ShotWithAllFeaturesFragmentDoc} | ||||
| `; | ||||
| export type EditShotMutationFn = Apollo.MutationFunction< | ||||
|   EditShotMutation, | ||||
|   EditShotMutationVariables | ||||
| >; | ||||
|  | ||||
| /** | ||||
|  * __useEditShotMutation__ | ||||
|  * | ||||
|  * To run a mutation, you first call `useEditShotMutation` within a React component and pass it any options that fit your needs. | ||||
|  * When your component renders, `useEditShotMutation` returns a tuple that includes: | ||||
|  * - A mutate function that you can call at any time to execute the mutation | ||||
|  * - An object with fields that represent the current status of the mutation's execution | ||||
|  * | ||||
|  * @param baseOptions options that will be passed into the mutation, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options-2; | ||||
|  * | ||||
|  * @example | ||||
|  * const [editShotMutation, { data, loading, error }] = useEditShotMutation({ | ||||
|  *   variables: { | ||||
|  *      shotId: // value for 'shotId' | ||||
|  *      fieldsToEdit: // value for 'fieldsToEdit' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useEditShotMutation( | ||||
|   baseOptions?: Apollo.MutationHookOptions< | ||||
|     EditShotMutation, | ||||
|     EditShotMutationVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useMutation<EditShotMutation, EditShotMutationVariables>( | ||||
|     EditShotDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export type EditShotMutationHookResult = ReturnType<typeof useEditShotMutation>; | ||||
| export type EditShotMutationResult = Apollo.MutationResult<EditShotMutation>; | ||||
| export type EditShotMutationOptions = Apollo.BaseMutationOptions< | ||||
|   EditShotMutation, | ||||
|   EditShotMutationVariables | ||||
| >; | ||||
| export const GetProfileImageUploadLinkDocument = gql` | ||||
|   mutation getProfileImageUploadLink($fileExt: String = ".png") { | ||||
|     getProfileImageUploadLink(fileExt: $fileExt) { | ||||
| @@ -5621,8 +6133,8 @@ export type GetLoggedInUserQueryResult = Apollo.QueryResult< | ||||
|   GetLoggedInUserQueryVariables | ||||
| >; | ||||
| export const GetUserPlayTimeDocument = gql` | ||||
|   query GetUserPlayTime($userId: Int!) { | ||||
|     getPlayTime(userId: $userId) { | ||||
|   query GetUserPlayTime($userId: Int!, $filters: VideoFilterInput) { | ||||
|     getPlayTime(userId: $userId, filters: $filters) { | ||||
|       totalSeconds | ||||
|     } | ||||
|   } | ||||
| @@ -5641,6 +6153,7 @@ export const GetUserPlayTimeDocument = gql` | ||||
|  * const { data, loading, error } = useGetUserPlayTimeQuery({ | ||||
|  *   variables: { | ||||
|  *      userId: // value for 'userId' | ||||
|  *      filters: // value for 'filters' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| @@ -6375,6 +6888,7 @@ export const GetVideoUpdatePageDetailsDocument = gql` | ||||
|       makePercentage | ||||
|       elapsedTime | ||||
|       tableSize | ||||
|       private | ||||
|       tags { | ||||
|         tagClasses { | ||||
|           name | ||||
| @@ -6515,6 +7029,7 @@ export const GetVideoDetailsDocument = gql` | ||||
|       createdAt | ||||
|       updatedAt | ||||
|       tableSize | ||||
|       private | ||||
|       owner { | ||||
|         id | ||||
|         firebaseUid | ||||
|   | ||||
| @@ -6,32 +6,7 @@ query GetFeed( | ||||
| ) { | ||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|     videos { | ||||
|       id | ||||
|       owner { | ||||
|         username | ||||
|       } | ||||
|       name | ||||
|       screenshotUri | ||||
|       totalShotsMade | ||||
|       totalShots | ||||
|       makePercentage | ||||
|       createdAt | ||||
|       updatedAt | ||||
|       startTime | ||||
|       endTime | ||||
|       elapsedTime | ||||
|       screenshotUri | ||||
|       stream { | ||||
|         id | ||||
|         isCompleted | ||||
|       } | ||||
|       tableSize | ||||
|       tags { | ||||
|         tagClasses { | ||||
|           name | ||||
|         } | ||||
|         name | ||||
|       } | ||||
|       ...VideoCardFields | ||||
|     } | ||||
|     pageInfo { | ||||
|       hasNextPage | ||||
| @@ -86,8 +61,14 @@ query GetVideoFeed( | ||||
|   $limit: Int! = 5 | ||||
|   $after: String = null | ||||
|   $filters: VideoFilterInput = null | ||||
|   $includeCallersVideos: Boolean = null | ||||
| ) { | ||||
|   getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|   getFeedVideos( | ||||
|     limit: $limit | ||||
|     after: $after | ||||
|     filters: $filters | ||||
|     includeCallersVideos: $includeCallersVideos | ||||
|   ) { | ||||
|     videos { | ||||
|       ...VideoCardFields | ||||
|     } | ||||
|   | ||||
							
								
								
									
										75
									
								
								src/operations/medals.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								src/operations/medals.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| fragment MedalFields on MedalGQL { | ||||
|   count | ||||
|   nickname | ||||
| } | ||||
|  | ||||
| query getMedals($scope: MedalScope!, $userId: Int) { | ||||
|   getMedals(scope: $scope, userId: $userId) { | ||||
|     distanceOver78 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     distanceOver90 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength3 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength5 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength8 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength10 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength15 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength20 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength25 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength30 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength40 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength50 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes100 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes500 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes1000 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes5000 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes10000 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes50 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes100 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes150 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes200 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes250 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -159,6 +159,7 @@ fragment ShotWithAllFeatures on ShotGQL { | ||||
|     targetPocketAngleDirection | ||||
|     marginOfErrorInDegrees | ||||
|     intendedPocketType | ||||
|     difficulty | ||||
|   } | ||||
|   pocketingIntentionInfo { | ||||
|     ballId | ||||
| @@ -177,3 +178,15 @@ fragment ShotWithAllFeatures on ShotGQL { | ||||
|     notes | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { | ||||
|   editShot(shotId: $shotId, fieldsToEdit: $fieldsToEdit) { | ||||
|     error { | ||||
|       shotId | ||||
|       msg | ||||
|     } | ||||
|     shot { | ||||
|       ...ShotWithAllFeatures | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -45,8 +45,8 @@ query getLoggedInUser { | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetUserPlayTime($userId: Int!) { | ||||
|   getPlayTime(userId: $userId) { | ||||
| query GetUserPlayTime($userId: Int!, $filters: VideoFilterInput) { | ||||
|   getPlayTime(userId: $userId, filters: $filters) { | ||||
|     totalSeconds | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -36,6 +36,7 @@ query GetVideoUpdatePageDetails($videoId: Int!) { | ||||
|     makePercentage | ||||
|     elapsedTime | ||||
|     tableSize | ||||
|     private | ||||
|     tags { | ||||
|       tagClasses { | ||||
|         name | ||||
| @@ -65,6 +66,7 @@ query GetVideoDetails($videoId: Int!) { | ||||
|     createdAt | ||||
|     updatedAt | ||||
|     tableSize | ||||
|     private | ||||
|     owner { | ||||
|       id | ||||
|       firebaseUid | ||||
| @@ -222,6 +224,7 @@ mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | ||||
| } | ||||
|  | ||||
| fragment HomographyInfo on HomographyInfoGQL { | ||||
|   id | ||||
|   frameIndex | ||||
|   crop { | ||||
|     left | ||||
|   | ||||
							
								
								
									
										156
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										156
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -10,6 +10,13 @@ type Query { | ||||
|     intervalDuration: Int! = 300 | ||||
|   ): [MakePercentageIntervalGQL!]! | ||||
|   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! | ||||
|   getRuns( | ||||
|     filterInput: RunFilterInput! | ||||
|     runIds: [Int!] = null | ||||
|     runsOrdering: GetRunsOrdering = null | ||||
|     limit: Int! = 500 | ||||
|     countRespectsLimit: Boolean! = false | ||||
|   ): GetRunsResult! | ||||
|   getOrderedShots( | ||||
|     filterInput: FilterInput! | ||||
|     ids: [Int!] = null | ||||
| @@ -59,6 +66,7 @@ type Query { | ||||
|   getFeedVideos( | ||||
|     limit: Int! = 5 | ||||
|     after: String = null | ||||
|     includeCallersVideos: Boolean = true | ||||
|     filters: VideoFilterInput = null | ||||
|   ): VideoHistoryGQL! | ||||
| } | ||||
| @@ -285,42 +293,49 @@ type RequestedMedalsGQL { | ||||
|   runLength30: MedalGQL | ||||
|   runLength40: MedalGQL | ||||
|   runLength50: MedalGQL | ||||
|   totalMakes25: MedalGQL | ||||
|   totalMakes50: MedalGQL | ||||
|   totalMakes75: MedalGQL | ||||
|   totalMakes25: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes50: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes75: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes200: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes300: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes400: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes750: MedalGQL @deprecated(reason: "no longer supported") | ||||
|   totalMakes100: MedalGQL | ||||
|   totalMakes200: MedalGQL | ||||
|   totalMakes300: MedalGQL | ||||
|   totalMakes400: MedalGQL | ||||
|   totalMakes500: MedalGQL | ||||
|   totalMakes750: MedalGQL | ||||
|   totalMakes1000: MedalGQL | ||||
|   dayStreak2: MedalGQL | ||||
|   dayStreak3: MedalGQL | ||||
|   dayStreak4: MedalGQL | ||||
|   dayStreak5: MedalGQL | ||||
|   dayStreak6: MedalGQL | ||||
|   dayStreak7: MedalGQL | ||||
|   dayStreak14: MedalGQL | ||||
|   dayStreak21: MedalGQL | ||||
|   dayStreak30: MedalGQL | ||||
|   dayStreak60: MedalGQL | ||||
|   dayStreak90: MedalGQL | ||||
|   totalMakes5000: MedalGQL | ||||
|   totalMakes10000: MedalGQL | ||||
|   dailyMakes50: MedalGQL | ||||
|   dailyMakes100: MedalGQL | ||||
|   dailyMakes150: MedalGQL | ||||
|   dailyMakes200: MedalGQL | ||||
|   dailyMakes250: MedalGQL | ||||
| } | ||||
|  | ||||
| type MedalGQL { | ||||
|   count: Int! | ||||
|   nickname: String | ||||
| } | ||||
|  | ||||
| input MedalScope @oneOf { | ||||
|   videoId: Int | ||||
|   interval: TimeInterval | ||||
|     @deprecated(reason: "NO LONGER SUPPORTED, USE DATETIME_RANGE") | ||||
|   datetimeRange: DatetimeRangeAggregationInput | ||||
| } | ||||
|  | ||||
| type GetShotsResult { | ||||
|   shots: [ShotGQL!]! | ||||
| type GetRunsResult { | ||||
|   runs: [RunGQL!]! | ||||
|   count: Int | ||||
|   ids: [Int!]! | ||||
|   runIds: [Int!]! | ||||
| } | ||||
|  | ||||
| type RunGQL { | ||||
|   id: Int! | ||||
|   runLength: Int! | ||||
|   videoId: Int! | ||||
|   userId: Int! | ||||
|   shots: [ShotGQL!]! | ||||
| } | ||||
|  | ||||
| type ShotGQL { | ||||
| @@ -461,6 +476,7 @@ type UploadStreamGQL { | ||||
|   createdAt: DateTime! | ||||
|   updatedAt: DateTime! | ||||
|   segments: [UploadSegmentGQL!]! | ||||
|   clientUploadStatus: ClientUploadStatusEnum | ||||
|   resolution: VideoResolutionGQL! | ||||
|   streamSegmentType: StreamSegmentTypeEnum! | ||||
| } | ||||
| @@ -485,6 +501,11 @@ type UploadSegmentGQL { | ||||
|   linksRequested: Int! | ||||
| } | ||||
|  | ||||
| enum ClientUploadStatusEnum { | ||||
|   UPLOAD_ENABLED | ||||
|   UPLOAD_DISABLED | ||||
| } | ||||
|  | ||||
| type VideoResolutionGQL { | ||||
|   width: Int | ||||
|   height: Int | ||||
| @@ -572,33 +593,62 @@ type VideoProcessingStatusGQL { | ||||
|   updatedAt: DateTime | ||||
| } | ||||
|  | ||||
| input RunFilterInput { | ||||
|   videoId: [Int!] | ||||
|   userId: [Int!] | ||||
|   username: [String!] | ||||
|   andFilters: [RunFilterInput!] | ||||
|   orFilters: [RunFilterInput!] | ||||
|   notFilter: RunFilterInput | ||||
|   tableSize: FloatRangeFilter | ||||
|   createdAt: DateRangeFilter | ||||
|   runLength: FloatRangeFilter | ||||
| } | ||||
|  | ||||
| input GetRunsOrdering { | ||||
|   orderings: [RunsOrderingComponent!]! | ||||
| } | ||||
|  | ||||
| input RunsOrderingComponent @oneOf { | ||||
|   runLength: IntOrdering | ||||
|   videoId: IntOrdering | ||||
|   videoCreation: DatetimeOrdering | ||||
| } | ||||
|  | ||||
| input IntOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: Int = null | ||||
| } | ||||
|  | ||||
| input DatetimeOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: DateTime = null | ||||
| } | ||||
|  | ||||
| type GetShotsResult { | ||||
|   shots: [ShotGQL!]! | ||||
|   count: Int | ||||
|   ids: [Int!]! | ||||
| } | ||||
|  | ||||
| input GetShotsOrdering { | ||||
|   orderings: [ShotsOrderingComponent!]! | ||||
| } | ||||
|  | ||||
| input ShotsOrderingComponent @oneOf { | ||||
|   videoCreation: DatetimeShotOrdering | ||||
|   marginOfError: FloatShotOrdering | ||||
|   videoId: IntShotOrdering | ||||
|   startFrame: IntShotOrdering | ||||
|   runLength: IntShotOrdering | ||||
|   videoCreation: DatetimeOrdering | ||||
|   marginOfError: FloatOrdering | ||||
|   difficulty: FloatOrdering | ||||
|   videoId: IntOrdering | ||||
|   startFrame: IntOrdering | ||||
|   runLength: IntOrdering | ||||
| } | ||||
|  | ||||
| input DatetimeShotOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: DateTime = null | ||||
| } | ||||
|  | ||||
| input FloatShotOrdering { | ||||
| input FloatOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: Float = null | ||||
| } | ||||
|  | ||||
| input IntShotOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: Int = null | ||||
| } | ||||
|  | ||||
| input GetShotsPagination { | ||||
|   createdAfter: CreatedAfter! | ||||
|   startFrameAfter: Int! | ||||
| @@ -628,6 +678,7 @@ input VideoFilterInput { | ||||
|   isStreamCompleted: Boolean = null | ||||
|   requireCursorCompletion: Boolean! = true | ||||
|   createdAt: DateRangeFilter = null | ||||
|   excludeVideosWithNoShots: Boolean = null | ||||
| } | ||||
|  | ||||
| type VideoHistoryGQL { | ||||
| @@ -657,6 +708,10 @@ scalar JSON | ||||
| type Mutation { | ||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||
|   setLoggerLevel(path: String!, level: String!): Boolean! | ||||
|   editShot( | ||||
|     shotId: Int! | ||||
|     fieldsToEdit: EditableShotFieldInputGQL! | ||||
|   ): EditShotReturn! | ||||
|   addAnnotationToShot( | ||||
|     shotId: Int! | ||||
|     annotationName: String! | ||||
| @@ -694,6 +749,27 @@ input CreateBucketSetInput { | ||||
|   buckets: [BucketInputGQL!]! | ||||
| } | ||||
|  | ||||
| type EditShotReturn { | ||||
|   shot: ShotGQL | ||||
|   error: DoesNotOwnShotErr | ||||
| } | ||||
|  | ||||
| type DoesNotOwnShotErr { | ||||
|   shotId: Int! | ||||
|   msg: String | ||||
| } | ||||
|  | ||||
| input EditableShotFieldInputGQL { | ||||
|   intendedPocketType: PocketEnum | ||||
|   shotDirection: ShotDirectionEnum | ||||
|   spinType: SpinTypeEnum | ||||
|   targetPocketAngleDirection: ShotDirectionEnum | ||||
|   make: Boolean | ||||
|   backcut: Boolean | ||||
|   excludeFromStats: Boolean | ||||
|   notes: String | ||||
| } | ||||
|  | ||||
| type AddShotAnnotationReturn { | ||||
|   value: SuccessfulAddAddShotAnnotationErrors! | ||||
| } | ||||
| @@ -714,11 +790,6 @@ union DoesNotOwnShotErrOtherErrorNeedsNote = | ||||
|     DoesNotOwnShotErr | ||||
|   | OtherErrorNeedsNote | ||||
|  | ||||
| type DoesNotOwnShotErr { | ||||
|   shotId: Int! | ||||
|   msg: String | ||||
| } | ||||
|  | ||||
| type OtherErrorNeedsNote { | ||||
|   msg: String | ||||
| } | ||||
| @@ -779,6 +850,7 @@ input VideoMetadataInput { | ||||
|   streamSegmentType: StreamSegmentTypeEnum = null | ||||
|   private: Boolean = null | ||||
|   endStream: Boolean! = false | ||||
|   clientUploadStatus: ClientUploadStatusEnum = null | ||||
|   resolution: VideoResolution = null | ||||
|   framesPerSecond: Float = null | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user