Compare commits
	
		
			45 Commits
		
	
	
		
			kat/update
			...
			d0cf071934
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d0cf071934 | |||
| 6b410b3d78 | |||
| 607504261c | |||
| 0421be855d | |||
| 014aab473b | |||
| 353872401e | |||
| 433dfdaf74 | |||
| a2d9e688e9 | |||
| b3259dac1f | |||
| 0982b9e60c | |||
| 1710ae451c | |||
| de9e7dea6a | |||
| cfcf1dbcd2 | |||
| 05e3182e8b | |||
| baf139aab5 | |||
| b3b454ef83 | |||
| f6e4a1bc0b | |||
| 9d8155527d | |||
| 8690e81029 | |||
| 4ef13a482a | |||
| 9db95c4e6c | |||
| 249807c935 | |||
| eec79b2dc5 | |||
| 464c013095 | |||
| e2f4995cad | |||
| a43b286e39 | |||
| 148f5362f0 | |||
| 4d01e9814d | |||
| b9e3e1f310 | |||
| b0da48c4fb | |||
| 1e53dc21ee | |||
| 5c5014339f | |||
| 84188a6066 | |||
| 7c7be319d1 | |||
| 79784faba1 | |||
| f3ea44755c | |||
| 9b6559559c | |||
| 2398216bf2 | |||
| d942b91d17 | |||
| 24d9b9225e | |||
| f6f6404302 | |||
| 4609af726b | |||
| c5919c90d0 | |||
| 605adc3293 | |||
| b40554d38d | 
| @@ -7,7 +7,7 @@ readme = "README.md" | |||||||
| packages = [{include = "rbproto"}] | packages = [{include = "rbproto"}] | ||||||
|  |  | ||||||
| [tool.poetry.dependencies] | [tool.poetry.dependencies] | ||||||
| python = ">=3.10,<3.12" | python = ">=3.10,<=3.13" | ||||||
| protobuf = "^4.25.3" | protobuf = "^4.25.3" | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										732
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										732
									
								
								src/index.tsx
									
									
									
									
									
								
							| @@ -1974,6 +1974,15 @@ export type MakePercentageIntervalGql = { | |||||||
|   makePercentage: Scalars["Float"]["output"]; |   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 = { | export type MustHaveSetForUploadLinkErr = { | ||||||
|   __typename?: "MustHaveSetForUploadLinkErr"; |   __typename?: "MustHaveSetForUploadLinkErr"; | ||||||
|   framesPerSecond?: Maybe<Scalars["Boolean"]["output"]>; |   framesPerSecond?: Maybe<Scalars["Boolean"]["output"]>; | ||||||
| @@ -2154,11 +2163,13 @@ export enum ProcessingStatusEnum { | |||||||
|  |  | ||||||
| export type Query = { | export type Query = { | ||||||
|   __typename?: "Query"; |   __typename?: "Query"; | ||||||
|  |   doesUsernameExist: Scalars["Boolean"]["output"]; | ||||||
|   getAggregatedShotMetrics: Array<AggregateResultGql>; |   getAggregatedShotMetrics: Array<AggregateResultGql>; | ||||||
|   getBucketSet?: Maybe<BucketSetGql>; |   getBucketSet?: Maybe<BucketSetGql>; | ||||||
|   getDeployedConfig: DeployedConfigGql; |   getDeployedConfig: DeployedConfigGql; | ||||||
|   getFeedVideos: VideoHistoryGql; |   getFeedVideos: VideoHistoryGql; | ||||||
|   getLoggedInUser?: Maybe<UserGql>; |   getLoggedInUser?: Maybe<UserGql>; | ||||||
|  |   getMedals: RequestedMedalsGql; | ||||||
|   getOrderedShots: GetShotsResult; |   getOrderedShots: GetShotsResult; | ||||||
|   getPlayTime: UserPlayTimeGql; |   getPlayTime: UserPlayTimeGql; | ||||||
|   getShotAnnotationTypes: Array<ShotAnnotationTypeGql>; |   getShotAnnotationTypes: Array<ShotAnnotationTypeGql>; | ||||||
| @@ -2166,16 +2177,20 @@ export type Query = { | |||||||
|   getShotsByIds: Array<ShotGql>; |   getShotsByIds: Array<ShotGql>; | ||||||
|   getShotsWithMetadata: GetShotsResult; |   getShotsWithMetadata: GetShotsResult; | ||||||
|   getUser?: Maybe<UserGql>; |   getUser?: Maybe<UserGql>; | ||||||
|  |   getUserRelationshipsMatching: UserRelationshipsResult; | ||||||
|   getUserTags: Array<TagGql>; |   getUserTags: Array<TagGql>; | ||||||
|   getUserVideos: VideoHistoryGql; |   getUserVideos: VideoHistoryGql; | ||||||
|   getUsernames: Array<Scalars["String"]["output"]>; |   getUsernames: Array<Scalars["String"]["output"]>; | ||||||
|   getUsernamesAndFollowing: UsernamesAndFollowingResponse; |  | ||||||
|   getVideo: VideoGql; |   getVideo: VideoGql; | ||||||
|   getVideoMakePercentageIntervals: Array<MakePercentageIntervalGql>; |   getVideoMakePercentageIntervals: Array<MakePercentageIntervalGql>; | ||||||
|   getVideos: Array<VideoGql>; |   getVideos: Array<VideoGql>; | ||||||
|   waitFor: Scalars["Float"]["output"]; |   waitFor: Scalars["Float"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type QueryDoesUsernameExistArgs = { | ||||||
|  |   candidateUsername: Scalars["String"]["input"]; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type QueryGetAggregatedShotMetricsArgs = { | export type QueryGetAggregatedShotMetricsArgs = { | ||||||
|   aggregateInput: AggregateInputGql; |   aggregateInput: AggregateInputGql; | ||||||
| }; | }; | ||||||
| @@ -2190,7 +2205,13 @@ export type QueryGetFeedVideosArgs = { | |||||||
|   limit?: Scalars["Int"]["input"]; |   limit?: Scalars["Int"]["input"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type QueryGetMedalsArgs = { | ||||||
|  |   scope: MedalScope; | ||||||
|  |   userId?: InputMaybe<Scalars["Int"]["input"]>; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type QueryGetOrderedShotsArgs = { | export type QueryGetOrderedShotsArgs = { | ||||||
|  |   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||||
|   filterInput: FilterInput; |   filterInput: FilterInput; | ||||||
|   ids?: InputMaybe<Array<Scalars["Int"]["input"]>>; |   ids?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||||
|   limit?: Scalars["Int"]["input"]; |   limit?: Scalars["Int"]["input"]; | ||||||
| @@ -2206,6 +2227,7 @@ export type QueryGetShotAnnotationTypesArgs = { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| export type QueryGetShotsArgs = { | export type QueryGetShotsArgs = { | ||||||
|  |   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||||
|   filterInput: FilterInput; |   filterInput: FilterInput; | ||||||
|   limit?: Scalars["Int"]["input"]; |   limit?: Scalars["Int"]["input"]; | ||||||
|   shotsPagination?: InputMaybe<GetShotsPagination>; |   shotsPagination?: InputMaybe<GetShotsPagination>; | ||||||
| @@ -2216,6 +2238,7 @@ export type QueryGetShotsByIdsArgs = { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| export type QueryGetShotsWithMetadataArgs = { | export type QueryGetShotsWithMetadataArgs = { | ||||||
|  |   countRespectsLimit?: Scalars["Boolean"]["input"]; | ||||||
|   filterInput: FilterInput; |   filterInput: FilterInput; | ||||||
|   ids?: InputMaybe<Array<Scalars["Int"]["input"]>>; |   ids?: InputMaybe<Array<Scalars["Int"]["input"]>>; | ||||||
|   limit?: Scalars["Int"]["input"]; |   limit?: Scalars["Int"]["input"]; | ||||||
| @@ -2226,6 +2249,13 @@ export type QueryGetUserArgs = { | |||||||
|   userId: Scalars["Int"]["input"]; |   userId: Scalars["Int"]["input"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type QueryGetUserRelationshipsMatchingArgs = { | ||||||
|  |   after?: InputMaybe<Scalars["String"]["input"]>; | ||||||
|  |   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||||
|  |   matchString?: InputMaybe<Scalars["String"]["input"]>; | ||||||
|  |   userId: Scalars["Int"]["input"]; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type QueryGetUserVideosArgs = { | export type QueryGetUserVideosArgs = { | ||||||
|   after?: InputMaybe<Scalars["String"]["input"]>; |   after?: InputMaybe<Scalars["String"]["input"]>; | ||||||
|   filters?: InputMaybe<VideoFilterInput>; |   filters?: InputMaybe<VideoFilterInput>; | ||||||
| @@ -2239,13 +2269,6 @@ export type QueryGetUsernamesArgs = { | |||||||
|   matchString?: InputMaybe<Scalars["String"]["input"]>; |   matchString?: InputMaybe<Scalars["String"]["input"]>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type QueryGetUsernamesAndFollowingArgs = { |  | ||||||
|   after?: InputMaybe<Scalars["String"]["input"]>; |  | ||||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; |  | ||||||
|   matchString?: InputMaybe<Scalars["String"]["input"]>; |  | ||||||
|   userId: Scalars["Int"]["input"]; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| export type QueryGetVideoArgs = { | export type QueryGetVideoArgs = { | ||||||
|   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; |   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; | ||||||
|   videoId: Scalars["Int"]["input"]; |   videoId: Scalars["Int"]["input"]; | ||||||
| @@ -2264,6 +2287,44 @@ export type QueryWaitForArgs = { | |||||||
|   duration: Scalars["Float"]["input"]; |   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 = { | export type SegmentAlreadyUploadedErr = { | ||||||
|   __typename?: "SegmentAlreadyUploadedErr"; |   __typename?: "SegmentAlreadyUploadedErr"; | ||||||
|   segmentId: Scalars["Int"]["output"]; |   segmentId: Scalars["Int"]["output"]; | ||||||
| @@ -2508,11 +2569,11 @@ export type UserGql = { | |||||||
|   activeVideoId?: Maybe<Scalars["Int"]["output"]>; |   activeVideoId?: Maybe<Scalars["Int"]["output"]>; | ||||||
|   createdAt?: Maybe<Scalars["DateTime"]["output"]>; |   createdAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||||
|   fargoRating?: Maybe<Scalars["Int"]["output"]>; |   fargoRating?: Maybe<Scalars["Int"]["output"]>; | ||||||
|   firebaseUid: Scalars["String"]["output"]; |   firebaseUid?: Maybe<Scalars["String"]["output"]>; | ||||||
|   followers?: Maybe<Array<Scalars["Int"]["output"]>>; |   followers?: Maybe<Array<UserGql>>; | ||||||
|   following?: Maybe<Array<Scalars["Int"]["output"]>>; |   following?: Maybe<Array<UserGql>>; | ||||||
|   id: Scalars["Int"]["output"]; |   id: Scalars["Int"]["output"]; | ||||||
|   isAdmin: Scalars["Boolean"]["output"]; |   isAdmin?: Maybe<Scalars["Boolean"]["output"]>; | ||||||
|   profileImageUri?: Maybe<Scalars["String"]["output"]>; |   profileImageUri?: Maybe<Scalars["String"]["output"]>; | ||||||
|   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; |   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||||
|   username: Scalars["String"]["output"]; |   username: Scalars["String"]["output"]; | ||||||
| @@ -2523,11 +2584,17 @@ export type UserPlayTimeGql = { | |||||||
|   totalSeconds: Scalars["Float"]["output"]; |   totalSeconds: Scalars["Float"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type UsernamesAndFollowingResponse = { | export type UserRelationship = { | ||||||
|   __typename?: "UsernamesAndFollowingResponse"; |   __typename?: "UserRelationship"; | ||||||
|   followers: Array<Scalars["Int"]["output"]>; |   toUser: UserGql; | ||||||
|   following: Array<Scalars["Int"]["output"]>; |   toUserFollows: Scalars["Boolean"]["output"]; | ||||||
|   usernames: Array<Scalars["String"]["output"]>; |   toUserIsFollowedBy: Scalars["Boolean"]["output"]; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export type UserRelationshipsResult = { | ||||||
|  |   __typename?: "UserRelationshipsResult"; | ||||||
|  |   inquiringUser: UserGql; | ||||||
|  |   relationships: Array<UserRelationship>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type VideoFilterInput = { | export type VideoFilterInput = { | ||||||
| @@ -2719,6 +2786,54 @@ export type GetFeedQuery = { | |||||||
|   }; |   }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | 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"; | ||||||
|  |         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 }>; | ||||||
|  |       }>; | ||||||
|  |     }>; | ||||||
|  |     pageInfo: { | ||||||
|  |       __typename?: "PageInfoGQL"; | ||||||
|  |       hasNextPage: boolean; | ||||||
|  |       endCursor?: string | null; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type GetVideoMakePercentageIntervalsQueryVariables = Exact<{ | export type GetVideoMakePercentageIntervalsQueryVariables = Exact<{ | ||||||
|   videoId: Scalars["ID"]["input"]; |   videoId: Scalars["ID"]["input"]; | ||||||
|   intervalDuration: Scalars["Int"]["input"]; |   intervalDuration: Scalars["Int"]["input"]; | ||||||
| @@ -2798,14 +2913,14 @@ export type UpdateShotAnnotationsMutation = { | |||||||
|  |  | ||||||
| export type GetShotsWithVideoGqlQueryVariables = Exact<{ | export type GetShotsWithVideoGqlQueryVariables = Exact<{ | ||||||
|   filterInput: FilterInput; |   filterInput: FilterInput; | ||||||
|  |   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; |   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||||
| }>; | }>; | ||||||
|  |  | ||||||
| export type GetShotsWithVideoGqlQuery = { | export type GetShotsWithVideoGqlQuery = { | ||||||
|   __typename?: "Query"; |   __typename?: "Query"; | ||||||
|   getShotsWithMetadata: { |   getOrderedShots: { | ||||||
|     __typename?: "GetShotsResult"; |     __typename?: "GetShotsResult"; | ||||||
|     ids: Array<number>; |  | ||||||
|     shots: Array<{ |     shots: Array<{ | ||||||
|       __typename?: "ShotGQL"; |       __typename?: "ShotGQL"; | ||||||
|       id: number; |       id: number; | ||||||
| @@ -2824,6 +2939,7 @@ export type GetShotsWithMetadataFilterResultQueryVariables = Exact<{ | |||||||
|   shotsOrdering?: InputMaybe<GetShotsOrdering>; |   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; |   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||||
|   ids?: InputMaybe<Array<Scalars["Int"]["input"]> | Scalars["Int"]["input"]>; |   ids?: InputMaybe<Array<Scalars["Int"]["input"]> | Scalars["Int"]["input"]>; | ||||||
|  |   countRespectsLimit?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||||
| }>; | }>; | ||||||
|  |  | ||||||
| export type GetShotsWithMetadataFilterResultQuery = { | export type GetShotsWithMetadataFilterResultQuery = { | ||||||
| @@ -3089,7 +3205,7 @@ export type EditProfileImageUriMutation = { | |||||||
|   editProfileImageUri: { |   editProfileImageUri: { | ||||||
|     __typename?: "UserGQL"; |     __typename?: "UserGQL"; | ||||||
|     id: number; |     id: number; | ||||||
|     firebaseUid: string; |     firebaseUid?: string | null; | ||||||
|     username: string; |     username: string; | ||||||
|     profileImageUri?: string | null; |     profileImageUri?: string | null; | ||||||
|     createdAt?: any | null; |     createdAt?: any | null; | ||||||
| @@ -3104,10 +3220,11 @@ export type GetLoggedInUserQuery = { | |||||||
|   getLoggedInUser?: { |   getLoggedInUser?: { | ||||||
|     __typename?: "UserGQL"; |     __typename?: "UserGQL"; | ||||||
|     id: number; |     id: number; | ||||||
|     firebaseUid: string; |     firebaseUid?: string | null; | ||||||
|     username: string; |     username: string; | ||||||
|     isAdmin: boolean; |     isAdmin?: boolean | null; | ||||||
|     profileImageUri?: string | null; |     profileImageUri?: string | null; | ||||||
|  |     fargoRating?: number | null; | ||||||
|     activeVideoId?: number | null; |     activeVideoId?: number | null; | ||||||
|     createdAt?: any | null; |     createdAt?: any | null; | ||||||
|     updatedAt?: any | null; |     updatedAt?: any | null; | ||||||
| @@ -3134,19 +3251,23 @@ export type GetUsernamesQuery = { | |||||||
|   getUsernames: Array<string>; |   getUsernames: Array<string>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type GetUsernamesAndFollowingQueryVariables = Exact<{ | export type GetUserRelationshipsMatchingQueryVariables = Exact<{ | ||||||
|   userId: Scalars["Int"]["input"]; |   userId: Scalars["Int"]["input"]; | ||||||
|   matchString: Scalars["String"]["input"]; |   matchString: Scalars["String"]["input"]; | ||||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; |   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||||
|   after?: InputMaybe<Scalars["String"]["input"]>; |   after?: InputMaybe<Scalars["String"]["input"]>; | ||||||
| }>; | }>; | ||||||
|  |  | ||||||
| export type GetUsernamesAndFollowingQuery = { | export type GetUserRelationshipsMatchingQuery = { | ||||||
|   __typename?: "Query"; |   __typename?: "Query"; | ||||||
|   getUsernamesAndFollowing: { |   getUserRelationshipsMatching: { | ||||||
|     __typename?: "UsernamesAndFollowingResponse"; |     __typename?: "UserRelationshipsResult"; | ||||||
|     followers: Array<number>; |     relationships: Array<{ | ||||||
|     following: Array<number>; |       __typename?: "UserRelationship"; | ||||||
|  |       toUserFollows: boolean; | ||||||
|  |       toUserIsFollowedBy: boolean; | ||||||
|  |       toUser: { __typename?: "UserGQL"; username: string; id: number }; | ||||||
|  |     }>; | ||||||
|   }; |   }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -3157,6 +3278,83 @@ export type GetUserTagsQuery = { | |||||||
|   getUserTags: Array<{ __typename?: "TagGQL"; id: number; name: string }>; |   getUserTags: Array<{ __typename?: "TagGQL"; id: number; name: string }>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type FollowUserMutationVariables = Exact<{ | ||||||
|  |   followedUserId: Scalars["Int"]["input"]; | ||||||
|  | }>; | ||||||
|  |  | ||||||
|  | export type FollowUserMutation = { | ||||||
|  |   __typename?: "Mutation"; | ||||||
|  |   followUser: { | ||||||
|  |     __typename?: "UserGQL"; | ||||||
|  |     username: string; | ||||||
|  |     id: number; | ||||||
|  |     following?: Array<{ | ||||||
|  |       __typename?: "UserGQL"; | ||||||
|  |       id: number; | ||||||
|  |       username: string; | ||||||
|  |     }> | null; | ||||||
|  |     followers?: Array<{ | ||||||
|  |       __typename?: "UserGQL"; | ||||||
|  |       id: number; | ||||||
|  |       username: string; | ||||||
|  |     }> | null; | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export type UnfollowUserMutationVariables = Exact<{ | ||||||
|  |   followedUserId: Scalars["Int"]["input"]; | ||||||
|  | }>; | ||||||
|  |  | ||||||
|  | export type UnfollowUserMutation = { | ||||||
|  |   __typename?: "Mutation"; | ||||||
|  |   unfollowUser: { | ||||||
|  |     __typename?: "UserGQL"; | ||||||
|  |     username: string; | ||||||
|  |     id: number; | ||||||
|  |     following?: Array<{ | ||||||
|  |       __typename?: "UserGQL"; | ||||||
|  |       id: number; | ||||||
|  |       username: string; | ||||||
|  |     }> | null; | ||||||
|  |     followers?: Array<{ | ||||||
|  |       __typename?: "UserGQL"; | ||||||
|  |       id: number; | ||||||
|  |       username: string; | ||||||
|  |     }> | null; | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export type GetUserFollowingFollowersQueryVariables = Exact<{ | ||||||
|  |   [key: string]: never; | ||||||
|  | }>; | ||||||
|  |  | ||||||
|  | export type GetUserFollowingFollowersQuery = { | ||||||
|  |   __typename?: "Query"; | ||||||
|  |   getLoggedInUser?: { | ||||||
|  |     __typename?: "UserGQL"; | ||||||
|  |     id: number; | ||||||
|  |     following?: Array<{ | ||||||
|  |       __typename?: "UserGQL"; | ||||||
|  |       id: number; | ||||||
|  |       username: string; | ||||||
|  |     }> | null; | ||||||
|  |     followers?: Array<{ | ||||||
|  |       __typename?: "UserGQL"; | ||||||
|  |       id: number; | ||||||
|  |       username: string; | ||||||
|  |     }> | null; | ||||||
|  |   } | null; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export type DoesUsernameExistQueryVariables = Exact<{ | ||||||
|  |   candidateUsername: Scalars["String"]["input"]; | ||||||
|  | }>; | ||||||
|  |  | ||||||
|  | export type DoesUsernameExistQuery = { | ||||||
|  |   __typename?: "Query"; | ||||||
|  |   doesUsernameExist: boolean; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type GetStreamMonitoringDetailsQueryVariables = Exact<{ | export type GetStreamMonitoringDetailsQueryVariables = Exact<{ | ||||||
|   videoId: Scalars["Int"]["input"]; |   videoId: Scalars["Int"]["input"]; | ||||||
|   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; |   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; | ||||||
| @@ -3275,7 +3473,7 @@ export type GetVideoDetailsQuery = { | |||||||
|     owner?: { |     owner?: { | ||||||
|       __typename?: "UserGQL"; |       __typename?: "UserGQL"; | ||||||
|       id: number; |       id: number; | ||||||
|       firebaseUid: string; |       firebaseUid?: string | null; | ||||||
|       username: string; |       username: string; | ||||||
|       profileImageUri?: string | null; |       profileImageUri?: string | null; | ||||||
|     } | null; |     } | null; | ||||||
| @@ -4135,6 +4333,117 @@ export type GetFeedQueryResult = Apollo.QueryResult< | |||||||
|   GetFeedQuery, |   GetFeedQuery, | ||||||
|   GetFeedQueryVariables |   GetFeedQueryVariables | ||||||
| >; | >; | ||||||
|  | export const GetVideoFeedDocument = gql` | ||||||
|  |   query GetVideoFeed( | ||||||
|  |     $limit: Int! = 5 | ||||||
|  |     $after: String = null | ||||||
|  |     $filters: VideoFilterInput = null | ||||||
|  |   ) { | ||||||
|  |     getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |       videos { | ||||||
|  |         id | ||||||
|  |         owner { | ||||||
|  |           username | ||||||
|  |           profileImageUri | ||||||
|  |         } | ||||||
|  |         name | ||||||
|  |         screenshotUri | ||||||
|  |         totalShotsMade | ||||||
|  |         totalShots | ||||||
|  |         makePercentage | ||||||
|  |         createdAt | ||||||
|  |         updatedAt | ||||||
|  |         startTime | ||||||
|  |         endTime | ||||||
|  |         elapsedTime | ||||||
|  |         screenshotUri | ||||||
|  |         stream { | ||||||
|  |           id | ||||||
|  |           isCompleted | ||||||
|  |         } | ||||||
|  |         tableSize | ||||||
|  |         tags { | ||||||
|  |           tagClasses { | ||||||
|  |             name | ||||||
|  |           } | ||||||
|  |           name | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       pageInfo { | ||||||
|  |         hasNextPage | ||||||
|  |         endCursor | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | `; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * __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` | export const GetVideoMakePercentageIntervalsDocument = gql` | ||||||
|   query GetVideoMakePercentageIntervals( |   query GetVideoMakePercentageIntervals( | ||||||
|     $videoId: ID! |     $videoId: ID! | ||||||
| @@ -4437,9 +4746,16 @@ export type UpdateShotAnnotationsMutationOptions = Apollo.BaseMutationOptions< | |||||||
|   UpdateShotAnnotationsMutationVariables |   UpdateShotAnnotationsMutationVariables | ||||||
| >; | >; | ||||||
| export const GetShotsWithVideoGqlDocument = gql` | export const GetShotsWithVideoGqlDocument = gql` | ||||||
|   query GetShotsWithVideoGql($filterInput: FilterInput!, $limit: Int) { |   query GetShotsWithVideoGql( | ||||||
|     getShotsWithMetadata(filterInput: $filterInput, limit: $limit) { |     $filterInput: FilterInput! | ||||||
|       ids |     $shotsOrdering: GetShotsOrdering | ||||||
|  |     $limit: Int | ||||||
|  |   ) { | ||||||
|  |     getOrderedShots( | ||||||
|  |       filterInput: $filterInput | ||||||
|  |       shotsOrdering: $shotsOrdering | ||||||
|  |       limit: $limit | ||||||
|  |     ) { | ||||||
|       shots { |       shots { | ||||||
|         id |         id | ||||||
|         videoId |         videoId | ||||||
| @@ -4465,6 +4781,7 @@ export const GetShotsWithVideoGqlDocument = gql` | |||||||
|  * const { data, loading, error } = useGetShotsWithVideoGqlQuery({ |  * const { data, loading, error } = useGetShotsWithVideoGqlQuery({ | ||||||
|  *   variables: { |  *   variables: { | ||||||
|  *      filterInput: // value for 'filterInput' |  *      filterInput: // value for 'filterInput' | ||||||
|  |  *      shotsOrdering: // value for 'shotsOrdering' | ||||||
|  *      limit: // value for 'limit' |  *      limit: // value for 'limit' | ||||||
|  *   }, |  *   }, | ||||||
|  * }); |  * }); | ||||||
| @@ -4524,12 +4841,14 @@ export const GetShotsWithMetadataFilterResultDocument = gql` | |||||||
|     $shotsOrdering: GetShotsOrdering |     $shotsOrdering: GetShotsOrdering | ||||||
|     $limit: Int |     $limit: Int | ||||||
|     $ids: [Int!] |     $ids: [Int!] | ||||||
|  |     $countRespectsLimit: Boolean | ||||||
|   ) { |   ) { | ||||||
|     getOrderedShots( |     getOrderedShots( | ||||||
|       filterInput: $filterInput |       filterInput: $filterInput | ||||||
|       shotsOrdering: $shotsOrdering |       shotsOrdering: $shotsOrdering | ||||||
|       limit: $limit |       limit: $limit | ||||||
|       ids: $ids |       ids: $ids | ||||||
|  |       countRespectsLimit: $countRespectsLimit | ||||||
|     ) { |     ) { | ||||||
|       count |       count | ||||||
|       shots { |       shots { | ||||||
| @@ -4557,6 +4876,7 @@ export const GetShotsWithMetadataFilterResultDocument = gql` | |||||||
|  *      shotsOrdering: // value for 'shotsOrdering' |  *      shotsOrdering: // value for 'shotsOrdering' | ||||||
|  *      limit: // value for 'limit' |  *      limit: // value for 'limit' | ||||||
|  *      ids: // value for 'ids' |  *      ids: // value for 'ids' | ||||||
|  |  *      countRespectsLimit: // value for 'countRespectsLimit' | ||||||
|  *   }, |  *   }, | ||||||
|  * }); |  * }); | ||||||
|  */ |  */ | ||||||
| @@ -4902,6 +5222,7 @@ export const GetLoggedInUserDocument = gql` | |||||||
|       username |       username | ||||||
|       isAdmin |       isAdmin | ||||||
|       profileImageUri |       profileImageUri | ||||||
|  |       fargoRating | ||||||
|       activeVideoId |       activeVideoId | ||||||
|       createdAt |       createdAt | ||||||
|       updatedAt |       updatedAt | ||||||
| @@ -5123,36 +5444,42 @@ export type GetUsernamesQueryResult = Apollo.QueryResult< | |||||||
|   GetUsernamesQuery, |   GetUsernamesQuery, | ||||||
|   GetUsernamesQueryVariables |   GetUsernamesQueryVariables | ||||||
| >; | >; | ||||||
| export const GetUsernamesAndFollowingDocument = gql` | export const GetUserRelationshipsMatchingDocument = gql` | ||||||
|   query getUsernamesAndFollowing( |   query getUserRelationshipsMatching( | ||||||
|     $userId: Int! |     $userId: Int! | ||||||
|     $matchString: String! |     $matchString: String! | ||||||
|     $limit: Int = null |     $limit: Int = null | ||||||
|     $after: String = null |     $after: String = null | ||||||
|   ) { |   ) { | ||||||
|     getUsernamesAndFollowing( |     getUserRelationshipsMatching( | ||||||
|       userId: $userId |       userId: $userId | ||||||
|       matchString: $matchString |       matchString: $matchString | ||||||
|       limit: $limit |       limit: $limit | ||||||
|       after: $after |       after: $after | ||||||
|     ) { |     ) { | ||||||
|       followers |       relationships { | ||||||
|       following |         toUser { | ||||||
|  |           username | ||||||
|  |           id | ||||||
|  |         } | ||||||
|  |         toUserFollows | ||||||
|  |         toUserIsFollowedBy | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| `; | `; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * __useGetUsernamesAndFollowingQuery__ |  * __useGetUserRelationshipsMatchingQuery__ | ||||||
|  * |  * | ||||||
|  * To run a query within a React component, call `useGetUsernamesAndFollowingQuery` and pass it any options that fit your needs. |  * To run a query within a React component, call `useGetUserRelationshipsMatchingQuery` and pass it any options that fit your needs. | ||||||
|  * When your component renders, `useGetUsernamesAndFollowingQuery` returns an object from Apollo Client that contains loading, error, and data properties |  * When your component renders, `useGetUserRelationshipsMatchingQuery` returns an object from Apollo Client that contains loading, error, and data properties | ||||||
|  * you can use to render your UI. |  * 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; |  * @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 |  * @example | ||||||
|  * const { data, loading, error } = useGetUsernamesAndFollowingQuery({ |  * const { data, loading, error } = useGetUserRelationshipsMatchingQuery({ | ||||||
|  *   variables: { |  *   variables: { | ||||||
|  *      userId: // value for 'userId' |  *      userId: // value for 'userId' | ||||||
|  *      matchString: // value for 'matchString' |  *      matchString: // value for 'matchString' | ||||||
| @@ -5161,54 +5488,54 @@ export const GetUsernamesAndFollowingDocument = gql` | |||||||
|  *   }, |  *   }, | ||||||
|  * }); |  * }); | ||||||
|  */ |  */ | ||||||
| export function useGetUsernamesAndFollowingQuery( | export function useGetUserRelationshipsMatchingQuery( | ||||||
|   baseOptions: Apollo.QueryHookOptions< |   baseOptions: Apollo.QueryHookOptions< | ||||||
|     GetUsernamesAndFollowingQuery, |     GetUserRelationshipsMatchingQuery, | ||||||
|     GetUsernamesAndFollowingQueryVariables |     GetUserRelationshipsMatchingQueryVariables | ||||||
|   >, |   >, | ||||||
| ) { | ) { | ||||||
|   const options = { ...defaultOptions, ...baseOptions }; |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|   return Apollo.useQuery< |   return Apollo.useQuery< | ||||||
|     GetUsernamesAndFollowingQuery, |     GetUserRelationshipsMatchingQuery, | ||||||
|     GetUsernamesAndFollowingQueryVariables |     GetUserRelationshipsMatchingQueryVariables | ||||||
|   >(GetUsernamesAndFollowingDocument, options); |   >(GetUserRelationshipsMatchingDocument, options); | ||||||
| } | } | ||||||
| export function useGetUsernamesAndFollowingLazyQuery( | export function useGetUserRelationshipsMatchingLazyQuery( | ||||||
|   baseOptions?: Apollo.LazyQueryHookOptions< |   baseOptions?: Apollo.LazyQueryHookOptions< | ||||||
|     GetUsernamesAndFollowingQuery, |     GetUserRelationshipsMatchingQuery, | ||||||
|     GetUsernamesAndFollowingQueryVariables |     GetUserRelationshipsMatchingQueryVariables | ||||||
|   >, |   >, | ||||||
| ) { | ) { | ||||||
|   const options = { ...defaultOptions, ...baseOptions }; |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|   return Apollo.useLazyQuery< |   return Apollo.useLazyQuery< | ||||||
|     GetUsernamesAndFollowingQuery, |     GetUserRelationshipsMatchingQuery, | ||||||
|     GetUsernamesAndFollowingQueryVariables |     GetUserRelationshipsMatchingQueryVariables | ||||||
|   >(GetUsernamesAndFollowingDocument, options); |   >(GetUserRelationshipsMatchingDocument, options); | ||||||
| } | } | ||||||
| export function useGetUsernamesAndFollowingSuspenseQuery( | export function useGetUserRelationshipsMatchingSuspenseQuery( | ||||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< |   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||||
|     GetUsernamesAndFollowingQuery, |     GetUserRelationshipsMatchingQuery, | ||||||
|     GetUsernamesAndFollowingQueryVariables |     GetUserRelationshipsMatchingQueryVariables | ||||||
|   >, |   >, | ||||||
| ) { | ) { | ||||||
|   const options = { ...defaultOptions, ...baseOptions }; |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|   return Apollo.useSuspenseQuery< |   return Apollo.useSuspenseQuery< | ||||||
|     GetUsernamesAndFollowingQuery, |     GetUserRelationshipsMatchingQuery, | ||||||
|     GetUsernamesAndFollowingQueryVariables |     GetUserRelationshipsMatchingQueryVariables | ||||||
|   >(GetUsernamesAndFollowingDocument, options); |   >(GetUserRelationshipsMatchingDocument, options); | ||||||
| } | } | ||||||
| export type GetUsernamesAndFollowingQueryHookResult = ReturnType< | export type GetUserRelationshipsMatchingQueryHookResult = ReturnType< | ||||||
|   typeof useGetUsernamesAndFollowingQuery |   typeof useGetUserRelationshipsMatchingQuery | ||||||
| >; | >; | ||||||
| export type GetUsernamesAndFollowingLazyQueryHookResult = ReturnType< | export type GetUserRelationshipsMatchingLazyQueryHookResult = ReturnType< | ||||||
|   typeof useGetUsernamesAndFollowingLazyQuery |   typeof useGetUserRelationshipsMatchingLazyQuery | ||||||
| >; | >; | ||||||
| export type GetUsernamesAndFollowingSuspenseQueryHookResult = ReturnType< | export type GetUserRelationshipsMatchingSuspenseQueryHookResult = ReturnType< | ||||||
|   typeof useGetUsernamesAndFollowingSuspenseQuery |   typeof useGetUserRelationshipsMatchingSuspenseQuery | ||||||
| >; | >; | ||||||
| export type GetUsernamesAndFollowingQueryResult = Apollo.QueryResult< | export type GetUserRelationshipsMatchingQueryResult = Apollo.QueryResult< | ||||||
|   GetUsernamesAndFollowingQuery, |   GetUserRelationshipsMatchingQuery, | ||||||
|   GetUsernamesAndFollowingQueryVariables |   GetUserRelationshipsMatchingQueryVariables | ||||||
| >; | >; | ||||||
| export const GetUserTagsDocument = gql` | export const GetUserTagsDocument = gql` | ||||||
|   query GetUserTags { |   query GetUserTags { | ||||||
| @@ -5281,6 +5608,275 @@ export type GetUserTagsQueryResult = Apollo.QueryResult< | |||||||
|   GetUserTagsQuery, |   GetUserTagsQuery, | ||||||
|   GetUserTagsQueryVariables |   GetUserTagsQueryVariables | ||||||
| >; | >; | ||||||
|  | export const FollowUserDocument = gql` | ||||||
|  |   mutation followUser($followedUserId: Int!) { | ||||||
|  |     followUser(followedUserId: $followedUserId) { | ||||||
|  |       username | ||||||
|  |       id | ||||||
|  |       following { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |       followers { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | `; | ||||||
|  | export type FollowUserMutationFn = Apollo.MutationFunction< | ||||||
|  |   FollowUserMutation, | ||||||
|  |   FollowUserMutationVariables | ||||||
|  | >; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * __useFollowUserMutation__ | ||||||
|  |  * | ||||||
|  |  * To run a mutation, you first call `useFollowUserMutation` within a React component and pass it any options that fit your needs. | ||||||
|  |  * When your component renders, `useFollowUserMutation` 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 [followUserMutation, { data, loading, error }] = useFollowUserMutation({ | ||||||
|  |  *   variables: { | ||||||
|  |  *      followedUserId: // value for 'followedUserId' | ||||||
|  |  *   }, | ||||||
|  |  * }); | ||||||
|  |  */ | ||||||
|  | export function useFollowUserMutation( | ||||||
|  |   baseOptions?: Apollo.MutationHookOptions< | ||||||
|  |     FollowUserMutation, | ||||||
|  |     FollowUserMutationVariables | ||||||
|  |   >, | ||||||
|  | ) { | ||||||
|  |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|  |   return Apollo.useMutation<FollowUserMutation, FollowUserMutationVariables>( | ||||||
|  |     FollowUserDocument, | ||||||
|  |     options, | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  | export type FollowUserMutationHookResult = ReturnType< | ||||||
|  |   typeof useFollowUserMutation | ||||||
|  | >; | ||||||
|  | export type FollowUserMutationResult = | ||||||
|  |   Apollo.MutationResult<FollowUserMutation>; | ||||||
|  | export type FollowUserMutationOptions = Apollo.BaseMutationOptions< | ||||||
|  |   FollowUserMutation, | ||||||
|  |   FollowUserMutationVariables | ||||||
|  | >; | ||||||
|  | export const UnfollowUserDocument = gql` | ||||||
|  |   mutation unfollowUser($followedUserId: Int!) { | ||||||
|  |     unfollowUser(followedUserId: $followedUserId) { | ||||||
|  |       username | ||||||
|  |       id | ||||||
|  |       following { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |       followers { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | `; | ||||||
|  | export type UnfollowUserMutationFn = Apollo.MutationFunction< | ||||||
|  |   UnfollowUserMutation, | ||||||
|  |   UnfollowUserMutationVariables | ||||||
|  | >; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * __useUnfollowUserMutation__ | ||||||
|  |  * | ||||||
|  |  * To run a mutation, you first call `useUnfollowUserMutation` within a React component and pass it any options that fit your needs. | ||||||
|  |  * When your component renders, `useUnfollowUserMutation` 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 [unfollowUserMutation, { data, loading, error }] = useUnfollowUserMutation({ | ||||||
|  |  *   variables: { | ||||||
|  |  *      followedUserId: // value for 'followedUserId' | ||||||
|  |  *   }, | ||||||
|  |  * }); | ||||||
|  |  */ | ||||||
|  | export function useUnfollowUserMutation( | ||||||
|  |   baseOptions?: Apollo.MutationHookOptions< | ||||||
|  |     UnfollowUserMutation, | ||||||
|  |     UnfollowUserMutationVariables | ||||||
|  |   >, | ||||||
|  | ) { | ||||||
|  |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|  |   return Apollo.useMutation< | ||||||
|  |     UnfollowUserMutation, | ||||||
|  |     UnfollowUserMutationVariables | ||||||
|  |   >(UnfollowUserDocument, options); | ||||||
|  | } | ||||||
|  | export type UnfollowUserMutationHookResult = ReturnType< | ||||||
|  |   typeof useUnfollowUserMutation | ||||||
|  | >; | ||||||
|  | export type UnfollowUserMutationResult = | ||||||
|  |   Apollo.MutationResult<UnfollowUserMutation>; | ||||||
|  | export type UnfollowUserMutationOptions = Apollo.BaseMutationOptions< | ||||||
|  |   UnfollowUserMutation, | ||||||
|  |   UnfollowUserMutationVariables | ||||||
|  | >; | ||||||
|  | export const GetUserFollowingFollowersDocument = gql` | ||||||
|  |   query getUserFollowingFollowers { | ||||||
|  |     getLoggedInUser { | ||||||
|  |       id | ||||||
|  |       following { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |       followers { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | `; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * __useGetUserFollowingFollowersQuery__ | ||||||
|  |  * | ||||||
|  |  * To run a query within a React component, call `useGetUserFollowingFollowersQuery` and pass it any options that fit your needs. | ||||||
|  |  * When your component renders, `useGetUserFollowingFollowersQuery` 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 } = useGetUserFollowingFollowersQuery({ | ||||||
|  |  *   variables: { | ||||||
|  |  *   }, | ||||||
|  |  * }); | ||||||
|  |  */ | ||||||
|  | export function useGetUserFollowingFollowersQuery( | ||||||
|  |   baseOptions?: Apollo.QueryHookOptions< | ||||||
|  |     GetUserFollowingFollowersQuery, | ||||||
|  |     GetUserFollowingFollowersQueryVariables | ||||||
|  |   >, | ||||||
|  | ) { | ||||||
|  |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|  |   return Apollo.useQuery< | ||||||
|  |     GetUserFollowingFollowersQuery, | ||||||
|  |     GetUserFollowingFollowersQueryVariables | ||||||
|  |   >(GetUserFollowingFollowersDocument, options); | ||||||
|  | } | ||||||
|  | export function useGetUserFollowingFollowersLazyQuery( | ||||||
|  |   baseOptions?: Apollo.LazyQueryHookOptions< | ||||||
|  |     GetUserFollowingFollowersQuery, | ||||||
|  |     GetUserFollowingFollowersQueryVariables | ||||||
|  |   >, | ||||||
|  | ) { | ||||||
|  |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|  |   return Apollo.useLazyQuery< | ||||||
|  |     GetUserFollowingFollowersQuery, | ||||||
|  |     GetUserFollowingFollowersQueryVariables | ||||||
|  |   >(GetUserFollowingFollowersDocument, options); | ||||||
|  | } | ||||||
|  | export function useGetUserFollowingFollowersSuspenseQuery( | ||||||
|  |   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||||
|  |     GetUserFollowingFollowersQuery, | ||||||
|  |     GetUserFollowingFollowersQueryVariables | ||||||
|  |   >, | ||||||
|  | ) { | ||||||
|  |   const options = { ...defaultOptions, ...baseOptions }; | ||||||
|  |   return Apollo.useSuspenseQuery< | ||||||
|  |     GetUserFollowingFollowersQuery, | ||||||
|  |     GetUserFollowingFollowersQueryVariables | ||||||
|  |   >(GetUserFollowingFollowersDocument, options); | ||||||
|  | } | ||||||
|  | export type GetUserFollowingFollowersQueryHookResult = ReturnType< | ||||||
|  |   typeof useGetUserFollowingFollowersQuery | ||||||
|  | >; | ||||||
|  | export type GetUserFollowingFollowersLazyQueryHookResult = ReturnType< | ||||||
|  |   typeof useGetUserFollowingFollowersLazyQuery | ||||||
|  | >; | ||||||
|  | export type GetUserFollowingFollowersSuspenseQueryHookResult = ReturnType< | ||||||
|  |   typeof useGetUserFollowingFollowersSuspenseQuery | ||||||
|  | >; | ||||||
|  | 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` | export const GetStreamMonitoringDetailsDocument = gql` | ||||||
|   query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { |   query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | ||||||
|     getVideo(videoId: $videoId, debuggingJson: $debuggingJson) { |     getVideo(videoId: $videoId, debuggingJson: $debuggingJson) { | ||||||
|   | |||||||
| @@ -38,3 +38,45 @@ query GetFeed( | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | query GetVideoFeed( | ||||||
|  |   $limit: Int! = 5 | ||||||
|  |   $after: String = null | ||||||
|  |   $filters: VideoFilterInput = null | ||||||
|  | ) { | ||||||
|  |   getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |     videos { | ||||||
|  |       id | ||||||
|  |       owner { | ||||||
|  |         username | ||||||
|  |         profileImageUri | ||||||
|  |       } | ||||||
|  |       name | ||||||
|  |       screenshotUri | ||||||
|  |       totalShotsMade | ||||||
|  |       totalShots | ||||||
|  |       makePercentage | ||||||
|  |       createdAt | ||||||
|  |       updatedAt | ||||||
|  |       startTime | ||||||
|  |       endTime | ||||||
|  |       elapsedTime | ||||||
|  |       screenshotUri | ||||||
|  |       stream { | ||||||
|  |         id | ||||||
|  |         isCompleted | ||||||
|  |       } | ||||||
|  |       tableSize | ||||||
|  |       tags { | ||||||
|  |         tagClasses { | ||||||
|  |           name | ||||||
|  |         } | ||||||
|  |         name | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     pageInfo { | ||||||
|  |       hasNextPage | ||||||
|  |       endCursor | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|   | |||||||
| @@ -40,9 +40,16 @@ mutation UpdateShotAnnotations( | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query GetShotsWithVideoGql($filterInput: FilterInput!, $limit: Int) { | query GetShotsWithVideoGql( | ||||||
|   getShotsWithMetadata(filterInput: $filterInput, limit: $limit) { |   $filterInput: FilterInput! | ||||||
|     ids |   $shotsOrdering: GetShotsOrdering | ||||||
|  |   $limit: Int | ||||||
|  | ) { | ||||||
|  |   getOrderedShots( | ||||||
|  |     filterInput: $filterInput | ||||||
|  |     shotsOrdering: $shotsOrdering | ||||||
|  |     limit: $limit | ||||||
|  |   ) { | ||||||
|     shots { |     shots { | ||||||
|       id |       id | ||||||
|       videoId |       videoId | ||||||
| @@ -60,12 +67,14 @@ query GetShotsWithMetadataFilterResult( | |||||||
|   $shotsOrdering: GetShotsOrdering |   $shotsOrdering: GetShotsOrdering | ||||||
|   $limit: Int |   $limit: Int | ||||||
|   $ids: [Int!] |   $ids: [Int!] | ||||||
|  |   $countRespectsLimit: Boolean | ||||||
| ) { | ) { | ||||||
|   getOrderedShots( |   getOrderedShots( | ||||||
|     filterInput: $filterInput |     filterInput: $filterInput | ||||||
|     shotsOrdering: $shotsOrdering |     shotsOrdering: $shotsOrdering | ||||||
|     limit: $limit |     limit: $limit | ||||||
|     ids: $ids |     ids: $ids | ||||||
|  |     countRespectsLimit: $countRespectsLimit | ||||||
|   ) { |   ) { | ||||||
|     count |     count | ||||||
|     shots { |     shots { | ||||||
|   | |||||||
| @@ -37,6 +37,7 @@ query getLoggedInUser { | |||||||
|     username |     username | ||||||
|     isAdmin |     isAdmin | ||||||
|     profileImageUri |     profileImageUri | ||||||
|  |     fargoRating | ||||||
|     activeVideoId |     activeVideoId | ||||||
|     createdAt |     createdAt | ||||||
|     updatedAt |     updatedAt | ||||||
| @@ -57,20 +58,26 @@ query getUsernames( | |||||||
|   getUsernames(matchString: $matchString, limit: $limit, after: $after) |   getUsernames(matchString: $matchString, limit: $limit, after: $after) | ||||||
| } | } | ||||||
|  |  | ||||||
| query getUsernamesAndFollowing( | query getUserRelationshipsMatching( | ||||||
|   $userId: Int! |   $userId: Int! | ||||||
|   $matchString: String! |   $matchString: String! | ||||||
|   $limit: Int = null |   $limit: Int = null | ||||||
|   $after: String = null |   $after: String = null | ||||||
| ) { | ) { | ||||||
|   getUsernamesAndFollowing( |   getUserRelationshipsMatching( | ||||||
|     userId: $userId |     userId: $userId | ||||||
|     matchString: $matchString |     matchString: $matchString | ||||||
|     limit: $limit |     limit: $limit | ||||||
|     after: $after |     after: $after | ||||||
|   ) { |   ) { | ||||||
|     followers |     relationships { | ||||||
|     following |       toUser { | ||||||
|  |         username | ||||||
|  |         id | ||||||
|  |       } | ||||||
|  |       toUserFollows | ||||||
|  |       toUserIsFollowedBy | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -80,3 +87,51 @@ query GetUserTags { | |||||||
|     name |     name | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | mutation followUser($followedUserId: Int!) { | ||||||
|  |   followUser(followedUserId: $followedUserId) { | ||||||
|  |     username | ||||||
|  |     id | ||||||
|  |     following { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |     } | ||||||
|  |     followers { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation unfollowUser($followedUserId: Int!) { | ||||||
|  |   unfollowUser(followedUserId: $followedUserId) { | ||||||
|  |     username | ||||||
|  |     id | ||||||
|  |     following { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |     } | ||||||
|  |     followers { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query getUserFollowingFollowers { | ||||||
|  |   getLoggedInUser { | ||||||
|  |     id | ||||||
|  |     following { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |     } | ||||||
|  |     followers { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query doesUsernameExist($candidateUsername: String!) { | ||||||
|  |   doesUsernameExist(candidateUsername: $candidateUsername) | ||||||
|  | } | ||||||
|   | |||||||
| @@ -9,38 +9,43 @@ type Query { | |||||||
|     videoId: ID! |     videoId: ID! | ||||||
|     intervalDuration: Int! = 300 |     intervalDuration: Int! = 300 | ||||||
|   ): [MakePercentageIntervalGQL!]! |   ): [MakePercentageIntervalGQL!]! | ||||||
|  |   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! | ||||||
|   getOrderedShots( |   getOrderedShots( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     ids: [Int!] = null |     ids: [Int!] = null | ||||||
|     shotsOrdering: GetShotsOrdering = null |     shotsOrdering: GetShotsOrdering = null | ||||||
|     limit: Int! = 500 |     limit: Int! = 500 | ||||||
|  |     countRespectsLimit: Boolean! = false | ||||||
|   ): GetShotsResult! |   ): GetShotsResult! | ||||||
|   getShotsWithMetadata( |   getShotsWithMetadata( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     ids: [Int!] = null |     ids: [Int!] = null | ||||||
|     shotsPagination: GetShotsPagination = null |     shotsPagination: GetShotsPagination = null | ||||||
|     limit: Int! = 500 |     limit: Int! = 500 | ||||||
|  |     countRespectsLimit: Boolean! = false | ||||||
|   ): GetShotsResult! |   ): GetShotsResult! | ||||||
|   getShots( |   getShots( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     shotsPagination: GetShotsPagination = null |     shotsPagination: GetShotsPagination = null | ||||||
|     limit: Int! = 500 |     limit: Int! = 500 | ||||||
|  |     countRespectsLimit: Boolean! = false | ||||||
|   ): [ShotGQL!]! |   ): [ShotGQL!]! | ||||||
|   getShotsByIds(ids: [Int!]!): [ShotGQL!]! |   getShotsByIds(ids: [Int!]!): [ShotGQL!]! | ||||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! |   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||||
|   getUser(userId: Int!): UserGQL |   getUser(userId: Int!): UserGQL | ||||||
|  |   doesUsernameExist(candidateUsername: String!): Boolean! | ||||||
|   getLoggedInUser: UserGQL |   getLoggedInUser: UserGQL | ||||||
|   getUsernames( |   getUsernames( | ||||||
|     matchString: String = null |     matchString: String = null | ||||||
|     limit: Int = null |     limit: Int = null | ||||||
|     after: String = null |     after: String = null | ||||||
|   ): [String!]! |   ): [String!]! | ||||||
|   getUsernamesAndFollowing( |   getUserRelationshipsMatching( | ||||||
|     userId: Int! |     userId: Int! | ||||||
|     matchString: String = null |     matchString: String = null | ||||||
|     limit: Int = 100 |     limit: Int = 100 | ||||||
|     after: String = null |     after: String = null | ||||||
|   ): UsernamesAndFollowingResponse! |   ): UserRelationshipsResult! | ||||||
|   getPlayTime(userId: Int!): UserPlayTimeGQL! |   getPlayTime(userId: Int!): UserPlayTimeGQL! | ||||||
|   getUserVideos( |   getUserVideos( | ||||||
|     userId: Int = null |     userId: Int = null | ||||||
| @@ -266,6 +271,52 @@ type MakePercentageIntervalGQL { | |||||||
|   elapsedTime: Float! |   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 { | type GetShotsResult { | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|   count: Int |   count: Int | ||||||
| @@ -341,16 +392,16 @@ type SerializedShotPathsGQL { | |||||||
|  |  | ||||||
| type UserGQL { | type UserGQL { | ||||||
|   id: Int! |   id: Int! | ||||||
|   firebaseUid: String! |   firebaseUid: String | ||||||
|   username: String! |   username: String! | ||||||
|   isAdmin: Boolean! |   isAdmin: Boolean | ||||||
|   fargoRating: Int |   fargoRating: Int | ||||||
|   activeVideoId: Int |   activeVideoId: Int | ||||||
|   profileImageUri: String |   profileImageUri: String | ||||||
|   createdAt: DateTime |   createdAt: DateTime | ||||||
|   updatedAt: DateTime |   updatedAt: DateTime | ||||||
|   following: [Int!] |   following: [UserGQL!] | ||||||
|   followers: [Int!] |   followers: [UserGQL!] | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotAnnotationGQL { | type ShotAnnotationGQL { | ||||||
| @@ -554,10 +605,15 @@ input CreatedAfter @oneOf { | |||||||
|   createdAt: DateTime |   createdAt: DateTime | ||||||
| } | } | ||||||
|  |  | ||||||
| type UsernamesAndFollowingResponse { | type UserRelationshipsResult { | ||||||
|   usernames: [String!]! |   inquiringUser: UserGQL! | ||||||
|   following: [Int!]! |   relationships: [UserRelationship!]! | ||||||
|   followers: [Int!]! | } | ||||||
|  |  | ||||||
|  | type UserRelationship { | ||||||
|  |   toUser: UserGQL! | ||||||
|  |   toUserFollows: Boolean! | ||||||
|  |   toUserIsFollowedBy: Boolean! | ||||||
| } | } | ||||||
|  |  | ||||||
| type UserPlayTimeGQL { | type UserPlayTimeGQL { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user