Compare commits
	
		
			33 Commits
		
	
	
		
			kat/use-lo
			...
			d5ba9c2ba5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d5ba9c2ba5 | |||
| 73771a263a | |||
| 655e59c43c | |||
| 056120a68a | |||
| bd7ffa7fdb | |||
| ec58923c65 | |||
| 63869cd7ca | |||
| 08ae9611cf | |||
| 4e610b7df2 | |||
| 2d6d3964ad | |||
| 73a58de36e | |||
| dc6f246489 | |||
| c0a3aa97dc | |||
| f4e43b24f2 | |||
| 51ab8320d7 | |||
| f9a00ad3eb | |||
| 998b2ffc8c | |||
| c7642e6204 | |||
| b2ce1c2f96 | |||
| d0cf071934 | |||
| 6b410b3d78 | |||
| 607504261c | |||
| 0421be855d | |||
| 014aab473b | |||
| 353872401e | |||
| 433dfdaf74 | |||
| a2d9e688e9 | |||
| b3259dac1f | |||
| 0982b9e60c | |||
| 1710ae451c | |||
| cfcf1dbcd2 | |||
| baf139aab5 | |||
| b3b454ef83 | 
							
								
								
									
										722
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										722
									
								
								src/index.tsx
									
									
									
									
									
								
							| @@ -1942,6 +1942,7 @@ export type HomographyInfoGql = { | ||||
|   crop: BoundingBoxGql; | ||||
|   destPoints: PocketPointsGql; | ||||
|   frameIndex: Scalars["Int"]["output"]; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   pockets: Array<BoundingBoxGql>; | ||||
|   sourcePoints: PocketPointsGql; | ||||
| }; | ||||
| @@ -1974,6 +1975,15 @@ export type MakePercentageIntervalGql = { | ||||
|   makePercentage: Scalars["Float"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type MedalGql = { | ||||
|   __typename?: "MedalGQL"; | ||||
|   count: Scalars["Int"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type MedalScope = | ||||
|   | { interval: TimeInterval; videoId?: never } | ||||
|   | { interval?: never; videoId: Scalars["Int"]["input"] }; | ||||
|  | ||||
| export type MustHaveSetForUploadLinkErr = { | ||||
|   __typename?: "MustHaveSetForUploadLinkErr"; | ||||
|   framesPerSecond?: Maybe<Scalars["Boolean"]["output"]>; | ||||
| @@ -1999,6 +2009,7 @@ export type Mutation = { | ||||
|   editProfileImageUri: UserGql; | ||||
|   editUploadStream: Scalars["Boolean"]["output"]; | ||||
|   editUser: UserGql; | ||||
|   findPrerecordTableLayout?: Maybe<HomographyInfoGql>; | ||||
|   followUser: UserGql; | ||||
|   getHlsInitUploadLink: GetUploadLinkReturn; | ||||
|   getProfileImageUploadLink: GetProfileUploadLinkReturn; | ||||
| @@ -2040,6 +2051,11 @@ export type MutationEditUserArgs = { | ||||
|   input: EditUserInputGql; | ||||
| }; | ||||
|  | ||||
| export type MutationFindPrerecordTableLayoutArgs = { | ||||
|   b64Image: Scalars["String"]["input"]; | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type MutationFollowUserArgs = { | ||||
|   followedUserId: Scalars["Int"]["input"]; | ||||
| }; | ||||
| @@ -2160,6 +2176,7 @@ export type Query = { | ||||
|   getDeployedConfig: DeployedConfigGql; | ||||
|   getFeedVideos: VideoHistoryGql; | ||||
|   getLoggedInUser?: Maybe<UserGql>; | ||||
|   getMedals: RequestedMedalsGql; | ||||
|   getOrderedShots: GetShotsResult; | ||||
|   getPlayTime: UserPlayTimeGql; | ||||
|   getShotAnnotationTypes: Array<ShotAnnotationTypeGql>; | ||||
| @@ -2195,7 +2212,13 @@ export type QueryGetFeedVideosArgs = { | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type QueryGetMedalsArgs = { | ||||
|   scope: MedalScope; | ||||
|   userId?: InputMaybe<Scalars["Int"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type QueryGetOrderedShotsArgs = { | ||||
|   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||
|   filterInput: FilterInput; | ||||
|   ids?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
| @@ -2211,6 +2234,7 @@ export type QueryGetShotAnnotationTypesArgs = { | ||||
| }; | ||||
|  | ||||
| export type QueryGetShotsArgs = { | ||||
|   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||
|   filterInput: FilterInput; | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
|   shotsPagination?: InputMaybe<GetShotsPagination>; | ||||
| @@ -2221,6 +2245,7 @@ export type QueryGetShotsByIdsArgs = { | ||||
| }; | ||||
|  | ||||
| export type QueryGetShotsWithMetadataArgs = { | ||||
|   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||
|   filterInput: FilterInput; | ||||
|   ids?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
| @@ -2269,6 +2294,44 @@ export type QueryWaitForArgs = { | ||||
|   duration: Scalars["Float"]["input"]; | ||||
| }; | ||||
|  | ||||
| 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>; | ||||
|   distanceOver66?: Maybe<MedalGql>; | ||||
|   distanceOver78?: Maybe<MedalGql>; | ||||
|   distanceOver90?: Maybe<MedalGql>; | ||||
|   runLength3?: Maybe<MedalGql>; | ||||
|   runLength5?: Maybe<MedalGql>; | ||||
|   runLength8?: Maybe<MedalGql>; | ||||
|   runLength10?: Maybe<MedalGql>; | ||||
|   runLength15?: Maybe<MedalGql>; | ||||
|   runLength20?: Maybe<MedalGql>; | ||||
|   runLength25?: Maybe<MedalGql>; | ||||
|   runLength30?: Maybe<MedalGql>; | ||||
|   runLength40?: Maybe<MedalGql>; | ||||
|   runLength50?: Maybe<MedalGql>; | ||||
|   totalMakes25?: Maybe<MedalGql>; | ||||
|   totalMakes50?: Maybe<MedalGql>; | ||||
|   totalMakes75?: Maybe<MedalGql>; | ||||
|   totalMakes100?: Maybe<MedalGql>; | ||||
|   totalMakes200?: Maybe<MedalGql>; | ||||
|   totalMakes300?: Maybe<MedalGql>; | ||||
|   totalMakes400?: Maybe<MedalGql>; | ||||
|   totalMakes500?: Maybe<MedalGql>; | ||||
|   totalMakes750?: Maybe<MedalGql>; | ||||
|   totalMakes1000?: Maybe<MedalGql>; | ||||
| }; | ||||
|  | ||||
| export type SegmentAlreadyUploadedErr = { | ||||
|   __typename?: "SegmentAlreadyUploadedErr"; | ||||
|   segmentId: Scalars["Int"]["output"]; | ||||
| @@ -2602,6 +2665,7 @@ export type VideoProcessingErrorGql = { | ||||
| export type VideoProcessingGql = { | ||||
|   __typename?: "VideoProcessingGQL"; | ||||
|   errors: Array<VideoProcessingErrorGql>; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   status: ProcessingStatusEnum; | ||||
|   statuses: Array<VideoProcessingStatusGql>; | ||||
| }; | ||||
| @@ -2730,6 +2794,110 @@ export type GetFeedQuery = { | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type VideoCardFieldsFragment = { | ||||
|   __typename?: "VideoGQL"; | ||||
|   id: number; | ||||
|   name?: string | null; | ||||
|   screenshotUri?: string | null; | ||||
|   totalShotsMade: number; | ||||
|   totalShots: number; | ||||
|   makePercentage: number; | ||||
|   createdAt?: any | null; | ||||
|   updatedAt?: any | null; | ||||
|   startTime?: any | null; | ||||
|   endTime?: any | null; | ||||
|   elapsedTime?: number | null; | ||||
|   tableSize: number; | ||||
|   owner?: { | ||||
|     __typename?: "UserGQL"; | ||||
|     id: number; | ||||
|     username: string; | ||||
|     profileImageUri?: string | null; | ||||
|   } | null; | ||||
|   stream?: { | ||||
|     __typename?: "UploadStreamGQL"; | ||||
|     id: string; | ||||
|     isCompleted: boolean; | ||||
|   } | null; | ||||
|   tags: Array<{ | ||||
|     __typename?: "VideoTag"; | ||||
|     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; | ||||
| }; | ||||
|  | ||||
| export type GetVideoFeedQueryVariables = Exact<{ | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
|   after?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   filters?: InputMaybe<VideoFilterInput>; | ||||
| }>; | ||||
|  | ||||
| export type GetVideoFeedQuery = { | ||||
|   __typename?: "Query"; | ||||
|   getFeedVideos: { | ||||
|     __typename?: "VideoHistoryGQL"; | ||||
|     videos: Array<{ | ||||
|       __typename?: "VideoGQL"; | ||||
|       id: number; | ||||
|       name?: string | null; | ||||
|       screenshotUri?: string | null; | ||||
|       totalShotsMade: number; | ||||
|       totalShots: number; | ||||
|       makePercentage: number; | ||||
|       createdAt?: any | null; | ||||
|       updatedAt?: any | null; | ||||
|       startTime?: any | null; | ||||
|       endTime?: any | null; | ||||
|       elapsedTime?: number | null; | ||||
|       tableSize: number; | ||||
|       owner?: { | ||||
|         __typename?: "UserGQL"; | ||||
|         id: number; | ||||
|         username: string; | ||||
|         profileImageUri?: string | null; | ||||
|       } | null; | ||||
|       stream?: { | ||||
|         __typename?: "UploadStreamGQL"; | ||||
|         id: string; | ||||
|         isCompleted: boolean; | ||||
|       } | null; | ||||
|       tags: Array<{ | ||||
|         __typename?: "VideoTag"; | ||||
|         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"; | ||||
|       hasNextPage: boolean; | ||||
|       endCursor?: string | null; | ||||
|     }; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetVideoMakePercentageIntervalsQueryVariables = Exact<{ | ||||
|   videoId: Scalars["ID"]["input"]; | ||||
|   intervalDuration: Scalars["Int"]["input"]; | ||||
| @@ -2830,11 +2998,26 @@ export type GetShotsWithVideoGqlQuery = { | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetShotsWithJustIdsQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
|   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type GetShotsWithJustIdsQuery = { | ||||
|   __typename?: "Query"; | ||||
|   getOrderedShots: { | ||||
|     __typename?: "GetShotsResult"; | ||||
|     shots: Array<{ __typename?: "ShotGQL"; id: number; videoId: number }>; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetShotsWithMetadataFilterResultQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
|   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   ids?: InputMaybe<Array<Scalars["Int"]["input"]> | Scalars["Int"]["input"]>; | ||||
|   countRespectsLimit?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type GetShotsWithMetadataFilterResultQuery = { | ||||
| @@ -3241,6 +3424,15 @@ export type GetUserFollowingFollowersQuery = { | ||||
|   } | null; | ||||
| }; | ||||
|  | ||||
| export type DoesUsernameExistQueryVariables = Exact<{ | ||||
|   candidateUsername: Scalars["String"]["input"]; | ||||
| }>; | ||||
|  | ||||
| export type DoesUsernameExistQuery = { | ||||
|   __typename?: "Query"; | ||||
|   doesUsernameExist: boolean; | ||||
| }; | ||||
|  | ||||
| export type GetStreamMonitoringDetailsQueryVariables = Exact<{ | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
|   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; | ||||
| @@ -3256,6 +3448,7 @@ export type GetStreamMonitoringDetailsQuery = { | ||||
|     elapsedTime?: number | null; | ||||
|     currentHomography?: { | ||||
|       __typename?: "HomographyInfoGQL"; | ||||
|       frameIndex: number; | ||||
|       crop: { | ||||
|         __typename?: "BoundingBoxGQL"; | ||||
|         left: number; | ||||
| @@ -3670,6 +3863,70 @@ export type GetHeaderInfoByVideoIdQuery = { | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type FindPrerecordTableLayoutMutationVariables = Exact<{ | ||||
|   b64Image: Scalars["String"]["input"]; | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }>; | ||||
|  | ||||
| export type FindPrerecordTableLayoutMutation = { | ||||
|   __typename?: "Mutation"; | ||||
|   findPrerecordTableLayout?: { | ||||
|     __typename?: "HomographyInfoGQL"; | ||||
|     frameIndex: number; | ||||
|     crop: { | ||||
|       __typename?: "BoundingBoxGQL"; | ||||
|       left: number; | ||||
|       top: number; | ||||
|       width: number; | ||||
|       height: number; | ||||
|     }; | ||||
|     pockets: Array<{ | ||||
|       __typename?: "BoundingBoxGQL"; | ||||
|       left: number; | ||||
|       top: number; | ||||
|       width: number; | ||||
|       height: number; | ||||
|     }>; | ||||
|     sourcePoints: { | ||||
|       __typename?: "PocketPointsGQL"; | ||||
|       topLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       topSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       topRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       bottomLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       bottomSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       bottomRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     }; | ||||
|   } | null; | ||||
| }; | ||||
|  | ||||
| export type HomographyInfoFragment = { | ||||
|   __typename?: "HomographyInfoGQL"; | ||||
|   frameIndex: number; | ||||
|   crop: { | ||||
|     __typename?: "BoundingBoxGQL"; | ||||
|     left: number; | ||||
|     top: number; | ||||
|     width: number; | ||||
|     height: number; | ||||
|   }; | ||||
|   pockets: Array<{ | ||||
|     __typename?: "BoundingBoxGQL"; | ||||
|     left: number; | ||||
|     top: number; | ||||
|     width: number; | ||||
|     height: number; | ||||
|   }>; | ||||
|   sourcePoints: { | ||||
|     __typename?: "PocketPointsGQL"; | ||||
|     topLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     topSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     topRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     bottomLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     bottomSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     bottomRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type CreateUploadStreamMutationVariables = Exact<{ | ||||
|   videoMetadataInput: VideoMetadataInput; | ||||
| }>; | ||||
| @@ -3842,6 +4099,48 @@ export type GetUploadStreamsWithDetailsQuery = { | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export const VideoCardFieldsFragmentDoc = gql` | ||||
|   fragment VideoCardFields on VideoGQL { | ||||
|     id | ||||
|     owner { | ||||
|       id | ||||
|       username | ||||
|       profileImageUri | ||||
|     } | ||||
|     name | ||||
|     screenshotUri | ||||
|     totalShotsMade | ||||
|     totalShots | ||||
|     makePercentage | ||||
|     createdAt | ||||
|     updatedAt | ||||
|     startTime | ||||
|     endTime | ||||
|     elapsedTime | ||||
|     screenshotUri | ||||
|     stream { | ||||
|       id | ||||
|       isCompleted | ||||
|     } | ||||
|     tableSize | ||||
|     tags { | ||||
|       tagClasses { | ||||
|         name | ||||
|       } | ||||
|       name | ||||
|     } | ||||
|     currentProcessing { | ||||
|       id | ||||
|       errors { | ||||
|         message | ||||
|       } | ||||
|       status | ||||
|       statuses { | ||||
|         status | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export const ShotWithAllFeaturesFragmentDoc = gql` | ||||
|   fragment ShotWithAllFeatures on ShotGQL { | ||||
|     id | ||||
| @@ -3960,6 +4259,49 @@ export const VideoDurationDataFragmentDoc = gql` | ||||
|   ${PlaylistWithSegmentStartTimesFragmentDoc} | ||||
|   ${StreamWithEndFramesFragmentDoc} | ||||
| `; | ||||
| export const HomographyInfoFragmentDoc = gql` | ||||
|   fragment HomographyInfo on HomographyInfoGQL { | ||||
|     frameIndex | ||||
|     crop { | ||||
|       left | ||||
|       top | ||||
|       width | ||||
|       height | ||||
|     } | ||||
|     pockets { | ||||
|       left | ||||
|       top | ||||
|       width | ||||
|       height | ||||
|     } | ||||
|     sourcePoints { | ||||
|       topLeft { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       topSide { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       topRight { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       bottomLeft { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       bottomSide { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       bottomRight { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export const GetAggregatedShotMetricsDocument = gql` | ||||
|   query GetAggregatedShotMetrics($aggregateInput: AggregateInputGQL!) { | ||||
|     getAggregatedShotMetrics(aggregateInput: $aggregateInput) { | ||||
| @@ -4219,6 +4561,92 @@ export type GetFeedQueryResult = Apollo.QueryResult< | ||||
|   GetFeedQuery, | ||||
|   GetFeedQueryVariables | ||||
| >; | ||||
| export const GetVideoFeedDocument = gql` | ||||
|   query GetVideoFeed( | ||||
|     $limit: Int! = 5 | ||||
|     $after: String = null | ||||
|     $filters: VideoFilterInput = null | ||||
|   ) { | ||||
|     getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|       videos { | ||||
|         ...VideoCardFields | ||||
|       } | ||||
|       pageInfo { | ||||
|         hasNextPage | ||||
|         endCursor | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${VideoCardFieldsFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
|  * __useGetVideoFeedQuery__ | ||||
|  * | ||||
|  * To run a query within a React component, call `useGetVideoFeedQuery` and pass it any options that fit your needs. | ||||
|  * When your component renders, `useGetVideoFeedQuery` 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 } = useGetVideoFeedQuery({ | ||||
|  *   variables: { | ||||
|  *      limit: // value for 'limit' | ||||
|  *      after: // value for 'after' | ||||
|  *      filters: // value for 'filters' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useGetVideoFeedQuery( | ||||
|   baseOptions?: Apollo.QueryHookOptions< | ||||
|     GetVideoFeedQuery, | ||||
|     GetVideoFeedQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useQuery<GetVideoFeedQuery, GetVideoFeedQueryVariables>( | ||||
|     GetVideoFeedDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export function useGetVideoFeedLazyQuery( | ||||
|   baseOptions?: Apollo.LazyQueryHookOptions< | ||||
|     GetVideoFeedQuery, | ||||
|     GetVideoFeedQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useLazyQuery<GetVideoFeedQuery, GetVideoFeedQueryVariables>( | ||||
|     GetVideoFeedDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export function useGetVideoFeedSuspenseQuery( | ||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||
|     GetVideoFeedQuery, | ||||
|     GetVideoFeedQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useSuspenseQuery<GetVideoFeedQuery, GetVideoFeedQueryVariables>( | ||||
|     GetVideoFeedDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export type GetVideoFeedQueryHookResult = ReturnType< | ||||
|   typeof useGetVideoFeedQuery | ||||
| >; | ||||
| export type GetVideoFeedLazyQueryHookResult = ReturnType< | ||||
|   typeof useGetVideoFeedLazyQuery | ||||
| >; | ||||
| export type GetVideoFeedSuspenseQueryHookResult = ReturnType< | ||||
|   typeof useGetVideoFeedSuspenseQuery | ||||
| >; | ||||
| export type GetVideoFeedQueryResult = Apollo.QueryResult< | ||||
|   GetVideoFeedQuery, | ||||
|   GetVideoFeedQueryVariables | ||||
| >; | ||||
| export const GetVideoMakePercentageIntervalsDocument = gql` | ||||
|   query GetVideoMakePercentageIntervals( | ||||
|     $videoId: ID! | ||||
| @@ -4610,18 +5038,106 @@ export type GetShotsWithVideoGqlQueryResult = Apollo.QueryResult< | ||||
|   GetShotsWithVideoGqlQuery, | ||||
|   GetShotsWithVideoGqlQueryVariables | ||||
| >; | ||||
| export const GetShotsWithJustIdsDocument = gql` | ||||
|   query GetShotsWithJustIds( | ||||
|     $filterInput: FilterInput! | ||||
|     $shotsOrdering: GetShotsOrdering | ||||
|     $limit: Int | ||||
|   ) { | ||||
|     getOrderedShots( | ||||
|       filterInput: $filterInput | ||||
|       shotsOrdering: $shotsOrdering | ||||
|       limit: $limit | ||||
|     ) { | ||||
|       shots { | ||||
|         id | ||||
|         videoId | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
|  | ||||
| /** | ||||
|  * __useGetShotsWithJustIdsQuery__ | ||||
|  * | ||||
|  * To run a query within a React component, call `useGetShotsWithJustIdsQuery` and pass it any options that fit your needs. | ||||
|  * When your component renders, `useGetShotsWithJustIdsQuery` 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 } = useGetShotsWithJustIdsQuery({ | ||||
|  *   variables: { | ||||
|  *      filterInput: // value for 'filterInput' | ||||
|  *      shotsOrdering: // value for 'shotsOrdering' | ||||
|  *      limit: // value for 'limit' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useGetShotsWithJustIdsQuery( | ||||
|   baseOptions: Apollo.QueryHookOptions< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useQuery< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >(GetShotsWithJustIdsDocument, options); | ||||
| } | ||||
| export function useGetShotsWithJustIdsLazyQuery( | ||||
|   baseOptions?: Apollo.LazyQueryHookOptions< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useLazyQuery< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >(GetShotsWithJustIdsDocument, options); | ||||
| } | ||||
| export function useGetShotsWithJustIdsSuspenseQuery( | ||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useSuspenseQuery< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >(GetShotsWithJustIdsDocument, options); | ||||
| } | ||||
| export type GetShotsWithJustIdsQueryHookResult = ReturnType< | ||||
|   typeof useGetShotsWithJustIdsQuery | ||||
| >; | ||||
| export type GetShotsWithJustIdsLazyQueryHookResult = ReturnType< | ||||
|   typeof useGetShotsWithJustIdsLazyQuery | ||||
| >; | ||||
| export type GetShotsWithJustIdsSuspenseQueryHookResult = ReturnType< | ||||
|   typeof useGetShotsWithJustIdsSuspenseQuery | ||||
| >; | ||||
| export type GetShotsWithJustIdsQueryResult = Apollo.QueryResult< | ||||
|   GetShotsWithJustIdsQuery, | ||||
|   GetShotsWithJustIdsQueryVariables | ||||
| >; | ||||
| export const GetShotsWithMetadataFilterResultDocument = gql` | ||||
|   query GetShotsWithMetadataFilterResult( | ||||
|     $filterInput: FilterInput! | ||||
|     $shotsOrdering: GetShotsOrdering | ||||
|     $limit: Int | ||||
|     $ids: [Int!] | ||||
|     $countRespectsLimit: Boolean | ||||
|   ) { | ||||
|     getOrderedShots( | ||||
|       filterInput: $filterInput | ||||
|       shotsOrdering: $shotsOrdering | ||||
|       limit: $limit | ||||
|       ids: $ids | ||||
|       countRespectsLimit: $countRespectsLimit | ||||
|     ) { | ||||
|       count | ||||
|       shots { | ||||
| @@ -4649,6 +5165,7 @@ export const GetShotsWithMetadataFilterResultDocument = gql` | ||||
|  *      shotsOrdering: // value for 'shotsOrdering' | ||||
|  *      limit: // value for 'limit' | ||||
|  *      ids: // value for 'ids' | ||||
|  *      countRespectsLimit: // value for 'countRespectsLimit' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| @@ -5578,6 +6095,77 @@ export type GetUserFollowingFollowersQueryResult = Apollo.QueryResult< | ||||
|   GetUserFollowingFollowersQuery, | ||||
|   GetUserFollowingFollowersQueryVariables | ||||
| >; | ||||
| export const DoesUsernameExistDocument = gql` | ||||
|   query doesUsernameExist($candidateUsername: String!) { | ||||
|     doesUsernameExist(candidateUsername: $candidateUsername) | ||||
|   } | ||||
| `; | ||||
|  | ||||
| /** | ||||
|  * __useDoesUsernameExistQuery__ | ||||
|  * | ||||
|  * To run a query within a React component, call `useDoesUsernameExistQuery` and pass it any options that fit your needs. | ||||
|  * When your component renders, `useDoesUsernameExistQuery` 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 } = useDoesUsernameExistQuery({ | ||||
|  *   variables: { | ||||
|  *      candidateUsername: // value for 'candidateUsername' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useDoesUsernameExistQuery( | ||||
|   baseOptions: Apollo.QueryHookOptions< | ||||
|     DoesUsernameExistQuery, | ||||
|     DoesUsernameExistQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useQuery< | ||||
|     DoesUsernameExistQuery, | ||||
|     DoesUsernameExistQueryVariables | ||||
|   >(DoesUsernameExistDocument, options); | ||||
| } | ||||
| export function useDoesUsernameExistLazyQuery( | ||||
|   baseOptions?: Apollo.LazyQueryHookOptions< | ||||
|     DoesUsernameExistQuery, | ||||
|     DoesUsernameExistQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useLazyQuery< | ||||
|     DoesUsernameExistQuery, | ||||
|     DoesUsernameExistQueryVariables | ||||
|   >(DoesUsernameExistDocument, options); | ||||
| } | ||||
| export function useDoesUsernameExistSuspenseQuery( | ||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||
|     DoesUsernameExistQuery, | ||||
|     DoesUsernameExistQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useSuspenseQuery< | ||||
|     DoesUsernameExistQuery, | ||||
|     DoesUsernameExistQueryVariables | ||||
|   >(DoesUsernameExistDocument, options); | ||||
| } | ||||
| export type DoesUsernameExistQueryHookResult = ReturnType< | ||||
|   typeof useDoesUsernameExistQuery | ||||
| >; | ||||
| export type DoesUsernameExistLazyQueryHookResult = ReturnType< | ||||
|   typeof useDoesUsernameExistLazyQuery | ||||
| >; | ||||
| export type DoesUsernameExistSuspenseQueryHookResult = ReturnType< | ||||
|   typeof useDoesUsernameExistSuspenseQuery | ||||
| >; | ||||
| export type DoesUsernameExistQueryResult = Apollo.QueryResult< | ||||
|   DoesUsernameExistQuery, | ||||
|   DoesUsernameExistQueryVariables | ||||
| >; | ||||
| export const GetStreamMonitoringDetailsDocument = gql` | ||||
|   query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | ||||
|     getVideo(videoId: $videoId, debuggingJson: $debuggingJson) { | ||||
| @@ -5586,44 +6174,7 @@ export const GetStreamMonitoringDetailsDocument = gql` | ||||
|       makePercentage | ||||
|       elapsedTime | ||||
|       currentHomography { | ||||
|         crop { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         pockets { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         sourcePoints { | ||||
|           topLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|         } | ||||
|         ...HomographyInfo | ||||
|       } | ||||
|       stream { | ||||
|         id | ||||
| @@ -5644,6 +6195,7 @@ export const GetStreamMonitoringDetailsDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -6093,45 +6645,7 @@ export const GetVideoDocument = gql` | ||||
|         segmentDurations | ||||
|       } | ||||
|       homographyHistory { | ||||
|         frameIndex | ||||
|         crop { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         pockets { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         sourcePoints { | ||||
|           topLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|         } | ||||
|         ...HomographyInfo | ||||
|       } | ||||
|       stream { | ||||
|         id | ||||
| @@ -6148,6 +6662,7 @@ export const GetVideoDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -6581,6 +7096,59 @@ export type GetHeaderInfoByVideoIdQueryResult = Apollo.QueryResult< | ||||
|   GetHeaderInfoByVideoIdQuery, | ||||
|   GetHeaderInfoByVideoIdQueryVariables | ||||
| >; | ||||
| export const FindPrerecordTableLayoutDocument = gql` | ||||
|   mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | ||||
|     findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { | ||||
|       ...HomographyInfo | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
| export type FindPrerecordTableLayoutMutationFn = Apollo.MutationFunction< | ||||
|   FindPrerecordTableLayoutMutation, | ||||
|   FindPrerecordTableLayoutMutationVariables | ||||
| >; | ||||
|  | ||||
| /** | ||||
|  * __useFindPrerecordTableLayoutMutation__ | ||||
|  * | ||||
|  * To run a mutation, you first call `useFindPrerecordTableLayoutMutation` within a React component and pass it any options that fit your needs. | ||||
|  * When your component renders, `useFindPrerecordTableLayoutMutation` 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 [findPrerecordTableLayoutMutation, { data, loading, error }] = useFindPrerecordTableLayoutMutation({ | ||||
|  *   variables: { | ||||
|  *      b64Image: // value for 'b64Image' | ||||
|  *      videoId: // value for 'videoId' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useFindPrerecordTableLayoutMutation( | ||||
|   baseOptions?: Apollo.MutationHookOptions< | ||||
|     FindPrerecordTableLayoutMutation, | ||||
|     FindPrerecordTableLayoutMutationVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useMutation< | ||||
|     FindPrerecordTableLayoutMutation, | ||||
|     FindPrerecordTableLayoutMutationVariables | ||||
|   >(FindPrerecordTableLayoutDocument, options); | ||||
| } | ||||
| export type FindPrerecordTableLayoutMutationHookResult = ReturnType< | ||||
|   typeof useFindPrerecordTableLayoutMutation | ||||
| >; | ||||
| export type FindPrerecordTableLayoutMutationResult = | ||||
|   Apollo.MutationResult<FindPrerecordTableLayoutMutation>; | ||||
| export type FindPrerecordTableLayoutMutationOptions = | ||||
|   Apollo.BaseMutationOptions< | ||||
|     FindPrerecordTableLayoutMutation, | ||||
|     FindPrerecordTableLayoutMutationVariables | ||||
|   >; | ||||
| export const CreateUploadStreamDocument = gql` | ||||
|   mutation CreateUploadStream($videoMetadataInput: VideoMetadataInput!) { | ||||
|     createUploadStream(videoMetadata: $videoMetadataInput) { | ||||
|   | ||||
| @@ -1,3 +1,4 @@ | ||||
| # DO NOT USE: use getVideoFeed instead | ||||
| query GetFeed( | ||||
|   $limit: Int! = 5 | ||||
|   $after: String = null | ||||
| @@ -38,3 +39,60 @@ query GetFeed( | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| fragment VideoCardFields on VideoGQL { | ||||
|   id | ||||
|   owner { | ||||
|     id | ||||
|     username | ||||
|     profileImageUri | ||||
|   } | ||||
|   name | ||||
|   screenshotUri | ||||
|   totalShotsMade | ||||
|   totalShots | ||||
|   makePercentage | ||||
|   createdAt | ||||
|   updatedAt | ||||
|   startTime | ||||
|   endTime | ||||
|   elapsedTime | ||||
|   screenshotUri | ||||
|   stream { | ||||
|     id | ||||
|     isCompleted | ||||
|   } | ||||
|   tableSize | ||||
|   tags { | ||||
|     tagClasses { | ||||
|       name | ||||
|     } | ||||
|     name | ||||
|   } | ||||
|   currentProcessing { | ||||
|     id | ||||
|     errors { | ||||
|       message | ||||
|     } | ||||
|     status | ||||
|     statuses { | ||||
|       status | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetVideoFeed( | ||||
|   $limit: Int! = 5 | ||||
|   $after: String = null | ||||
|   $filters: VideoFilterInput = null | ||||
| ) { | ||||
|   getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|     videos { | ||||
|       ...VideoCardFields | ||||
|     } | ||||
|     pageInfo { | ||||
|       hasNextPage | ||||
|       endCursor | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -40,6 +40,7 @@ mutation UpdateShotAnnotations( | ||||
|   } | ||||
| } | ||||
|  | ||||
| ## Should be deprecated | ||||
| query GetShotsWithVideoGql( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
| @@ -61,18 +62,37 @@ query GetShotsWithVideoGql( | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetShotsWithJustIds( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
|   $limit: Int | ||||
| ) { | ||||
|   getOrderedShots( | ||||
|     filterInput: $filterInput | ||||
|     shotsOrdering: $shotsOrdering | ||||
|     limit: $limit | ||||
|   ) { | ||||
|     shots { | ||||
|       id | ||||
|       videoId | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| ## Reserved for playlists (which are created from a filter) | ||||
| query GetShotsWithMetadataFilterResult( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
|   $limit: Int | ||||
|   $ids: [Int!] | ||||
|   $countRespectsLimit: Boolean | ||||
| ) { | ||||
|   getOrderedShots( | ||||
|     filterInput: $filterInput | ||||
|     shotsOrdering: $shotsOrdering | ||||
|     limit: $limit | ||||
|     ids: $ids | ||||
|     countRespectsLimit: $countRespectsLimit | ||||
|   ) { | ||||
|     count | ||||
|     shots { | ||||
|   | ||||
| @@ -131,3 +131,7 @@ query getUserFollowingFollowers { | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query doesUsernameExist($candidateUsername: String!) { | ||||
|   doesUsernameExist(candidateUsername: $candidateUsername) | ||||
| } | ||||
|   | ||||
| @@ -5,44 +5,7 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | ||||
|     makePercentage | ||||
|     elapsedTime | ||||
|     currentHomography { | ||||
|       crop { | ||||
|         left | ||||
|         top | ||||
|         width | ||||
|         height | ||||
|       } | ||||
|       pockets { | ||||
|         left | ||||
|         top | ||||
|         width | ||||
|         height | ||||
|       } | ||||
|       sourcePoints { | ||||
|         topLeft { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         topSide { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         topRight { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         bottomLeft { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         bottomSide { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         bottomRight { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|       } | ||||
|       ...HomographyInfo | ||||
|     } | ||||
|     stream { | ||||
|       id | ||||
| @@ -154,45 +117,7 @@ query GetVideo($videoId: Int!) { | ||||
|       segmentDurations | ||||
|     } | ||||
|     homographyHistory { | ||||
|       frameIndex | ||||
|       crop { | ||||
|         left | ||||
|         top | ||||
|         width | ||||
|         height | ||||
|       } | ||||
|       pockets { | ||||
|         left | ||||
|         top | ||||
|         width | ||||
|         height | ||||
|       } | ||||
|       sourcePoints { | ||||
|         topLeft { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         topSide { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         topRight { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         bottomLeft { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         bottomSide { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|         bottomRight { | ||||
|           x | ||||
|           y | ||||
|         } | ||||
|       } | ||||
|       ...HomographyInfo | ||||
|     } | ||||
|     stream { | ||||
|       id | ||||
| @@ -288,3 +213,51 @@ query GetHeaderInfoByVideoId($videoId: Int!) { | ||||
|     startTime | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | ||||
|   findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { | ||||
|     ...HomographyInfo | ||||
|   } | ||||
| } | ||||
|  | ||||
| fragment HomographyInfo on HomographyInfoGQL { | ||||
|   frameIndex | ||||
|   crop { | ||||
|     left | ||||
|     top | ||||
|     width | ||||
|     height | ||||
|   } | ||||
|   pockets { | ||||
|     left | ||||
|     top | ||||
|     width | ||||
|     height | ||||
|   } | ||||
|   sourcePoints { | ||||
|     topLeft { | ||||
|       x | ||||
|       y | ||||
|     } | ||||
|     topSide { | ||||
|       x | ||||
|       y | ||||
|     } | ||||
|     topRight { | ||||
|       x | ||||
|       y | ||||
|     } | ||||
|     bottomLeft { | ||||
|       x | ||||
|       y | ||||
|     } | ||||
|     bottomSide { | ||||
|       x | ||||
|       y | ||||
|     } | ||||
|     bottomRight { | ||||
|       x | ||||
|       y | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -9,22 +9,26 @@ type Query { | ||||
|     videoId: ID! | ||||
|     intervalDuration: Int! = 300 | ||||
|   ): [MakePercentageIntervalGQL!]! | ||||
|   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! | ||||
|   getOrderedShots( | ||||
|     filterInput: FilterInput! | ||||
|     ids: [Int!] = null | ||||
|     shotsOrdering: GetShotsOrdering = null | ||||
|     limit: Int! = 500 | ||||
|     countRespectsLimit: Boolean! = false | ||||
|   ): GetShotsResult! | ||||
|   getShotsWithMetadata( | ||||
|     filterInput: FilterInput! | ||||
|     ids: [Int!] = null | ||||
|     shotsPagination: GetShotsPagination = null | ||||
|     limit: Int! = 500 | ||||
|     countRespectsLimit: Boolean! = false | ||||
|   ): GetShotsResult! | ||||
|   getShots( | ||||
|     filterInput: FilterInput! | ||||
|     shotsPagination: GetShotsPagination = null | ||||
|     limit: Int! = 500 | ||||
|     countRespectsLimit: Boolean! = false | ||||
|   ): [ShotGQL!]! | ||||
|   getShotsByIds(ids: [Int!]!): [ShotGQL!]! | ||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||
| @@ -267,6 +271,52 @@ type MakePercentageIntervalGQL { | ||||
|   elapsedTime: Float! | ||||
| } | ||||
|  | ||||
| type RequestedMedalsGQL { | ||||
|   distanceOver66: MedalGQL | ||||
|   distanceOver78: MedalGQL | ||||
|   distanceOver90: MedalGQL | ||||
|   runLength3: MedalGQL | ||||
|   runLength5: MedalGQL | ||||
|   runLength8: MedalGQL | ||||
|   runLength10: MedalGQL | ||||
|   runLength15: MedalGQL | ||||
|   runLength20: MedalGQL | ||||
|   runLength25: MedalGQL | ||||
|   runLength30: MedalGQL | ||||
|   runLength40: MedalGQL | ||||
|   runLength50: MedalGQL | ||||
|   totalMakes25: MedalGQL | ||||
|   totalMakes50: MedalGQL | ||||
|   totalMakes75: MedalGQL | ||||
|   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 | ||||
| } | ||||
|  | ||||
| type MedalGQL { | ||||
|   count: Int! | ||||
| } | ||||
|  | ||||
| input MedalScope @oneOf { | ||||
|   videoId: Int | ||||
|   interval: TimeInterval | ||||
| } | ||||
|  | ||||
| type GetShotsResult { | ||||
|   shots: [ShotGQL!]! | ||||
|   count: Int | ||||
| @@ -459,6 +509,7 @@ type VideoTagClass { | ||||
| } | ||||
|  | ||||
| type HomographyInfoGQL { | ||||
|   id: Int! | ||||
|   frameIndex: Int! | ||||
|   crop: BoundingBoxGQL! | ||||
|   pockets: [BoundingBoxGQL!]! | ||||
| @@ -488,6 +539,7 @@ type IntPoint2D { | ||||
| } | ||||
|  | ||||
| type VideoProcessingGQL { | ||||
|   id: Int! | ||||
|   errors: [VideoProcessingErrorGQL!]! | ||||
|   status: ProcessingStatusEnum! | ||||
|   statuses: [VideoProcessingStatusGQL!]! | ||||
| @@ -618,6 +670,7 @@ type Mutation { | ||||
|   editUser(input: EditUserInputGQL!): UserGQL! | ||||
|   followUser(followedUserId: Int!): UserGQL! | ||||
|   unfollowUser(followedUserId: Int!): UserGQL! | ||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||
|   createUploadStream( | ||||
|     videoMetadata: VideoMetadataInput! | ||||
|   ): CreateUploadStreamReturn! | ||||
|   | ||||
		Reference in New Issue
	
	Block a user