Compare commits
	
		
			23 Commits
		
	
	
		
			c0a3aa97dc
			...
			volodymyr/
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 36b6804719 | |||
| 0120c15064 | |||
| 9cc99d956a | |||
| 985fa8b8e5 | |||
| c4868e7ebe | |||
| 58e1c18034 | |||
| 592dea0ca2 | |||
| 0e00ae9297 | |||
| e16812f242 | |||
| 3e9b7a0d16 | |||
| 309deb9473 | |||
| d5ba9c2ba5 | |||
| 73771a263a | |||
| 655e59c43c | |||
| 056120a68a | |||
| bd7ffa7fdb | |||
| ec58923c65 | |||
| 63869cd7ca | |||
| 08ae9611cf | |||
| 4e610b7df2 | |||
| 2d6d3964ad | |||
| 73a58de36e | |||
| dc6f246489 | 
							
								
								
									
										389
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										389
									
								
								src/index.tsx
									
									
									
									
									
								
							| @@ -184,6 +184,7 @@ export type DoesNotOwnShotErrOtherErrorNeedsNote = | ||||
| export type EditUserInputGql = { | ||||
|   fargoRating?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   username?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   videosPrivateByDefault?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type EnumAggregation = { | ||||
| @@ -1942,6 +1943,7 @@ export type HomographyInfoGql = { | ||||
|   crop: BoundingBoxGql; | ||||
|   destPoints: PocketPointsGql; | ||||
|   frameIndex: Scalars["Int"]["output"]; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   pockets: Array<BoundingBoxGql>; | ||||
|   sourcePoints: PocketPointsGql; | ||||
| }; | ||||
| @@ -2008,6 +2010,7 @@ export type Mutation = { | ||||
|   editProfileImageUri: UserGql; | ||||
|   editUploadStream: Scalars["Boolean"]["output"]; | ||||
|   editUser: UserGql; | ||||
|   findPrerecordTableLayout?: Maybe<HomographyInfoGql>; | ||||
|   followUser: UserGql; | ||||
|   getHlsInitUploadLink: GetUploadLinkReturn; | ||||
|   getProfileImageUploadLink: GetProfileUploadLinkReturn; | ||||
| @@ -2049,6 +2052,11 @@ export type MutationEditUserArgs = { | ||||
|   input: EditUserInputGql; | ||||
| }; | ||||
|  | ||||
| export type MutationFindPrerecordTableLayoutArgs = { | ||||
|   b64Image: Scalars["String"]["input"]; | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type MutationFollowUserArgs = { | ||||
|   followedUserId: Scalars["Int"]["input"]; | ||||
| }; | ||||
| @@ -2163,7 +2171,6 @@ export enum ProcessingStatusEnum { | ||||
|  | ||||
| export type Query = { | ||||
|   __typename?: "Query"; | ||||
|   checkHomographyIsValid?: Maybe<HomographyInfoGql>; | ||||
|   doesUsernameExist: Scalars["Boolean"]["output"]; | ||||
|   getAggregatedShotMetrics: Array<AggregateResultGql>; | ||||
|   getBucketSet?: Maybe<BucketSetGql>; | ||||
| @@ -2188,11 +2195,6 @@ export type Query = { | ||||
|   waitFor: Scalars["Float"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type QueryCheckHomographyIsValidArgs = { | ||||
|   b64Image: Scalars["String"]["input"]; | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type QueryDoesUsernameExistArgs = { | ||||
|   candidateUsername: Scalars["String"]["input"]; | ||||
| }; | ||||
| @@ -2225,6 +2227,7 @@ export type QueryGetOrderedShotsArgs = { | ||||
| }; | ||||
|  | ||||
| export type QueryGetPlayTimeArgs = { | ||||
|   filters?: InputMaybe<VideoFilterInput>; | ||||
|   userId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| @@ -2583,6 +2586,7 @@ export type UserGql = { | ||||
|   profileImageUri?: Maybe<Scalars["String"]["output"]>; | ||||
|   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||
|   username: Scalars["String"]["output"]; | ||||
|   videosPrivateByDefault?: Maybe<Scalars["Boolean"]["output"]>; | ||||
| }; | ||||
|  | ||||
| export type UserPlayTimeGql = { | ||||
| @@ -2604,6 +2608,7 @@ export type UserRelationshipsResult = { | ||||
| }; | ||||
|  | ||||
| export type VideoFilterInput = { | ||||
|   createdAt?: InputMaybe<DateRangeFilter>; | ||||
|   isStreamCompleted?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   requireCursorCompletion?: Scalars["Boolean"]["input"]; | ||||
| }; | ||||
| @@ -2624,6 +2629,7 @@ export type VideoGql = { | ||||
|   name?: Maybe<Scalars["String"]["output"]>; | ||||
|   owner?: Maybe<UserGql>; | ||||
|   playlist?: Maybe<HlsPlaylistGql>; | ||||
|   private: Scalars["Boolean"]["output"]; | ||||
|   screenshotUri?: Maybe<Scalars["String"]["output"]>; | ||||
|   shots: Array<ShotGql>; | ||||
|   startTime?: Maybe<Scalars["DateTime"]["output"]>; | ||||
| @@ -2647,6 +2653,7 @@ export type VideoMetadataInput = { | ||||
|   framesPerSecond?: InputMaybe<Scalars["Float"]["input"]>; | ||||
|   gameType?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   lastIntendedSegmentBound?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   private?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
|   resolution?: InputMaybe<VideoResolution>; | ||||
|   startTime?: InputMaybe<Scalars["DateTime"]["input"]>; | ||||
|   streamSegmentType?: InputMaybe<StreamSegmentTypeEnum>; | ||||
| @@ -2664,6 +2671,7 @@ export type VideoProcessingErrorGql = { | ||||
| export type VideoProcessingGql = { | ||||
|   __typename?: "VideoProcessingGQL"; | ||||
|   errors: Array<VideoProcessingErrorGql>; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   status: ProcessingStatusEnum; | ||||
|   statuses: Array<VideoProcessingStatusGql>; | ||||
| }; | ||||
| @@ -2804,6 +2812,7 @@ export type VideoCardFieldsFragment = { | ||||
|   updatedAt?: any | null; | ||||
|   startTime?: any | null; | ||||
|   endTime?: any | null; | ||||
|   private: boolean; | ||||
|   elapsedTime?: number | null; | ||||
|   tableSize: number; | ||||
|   owner?: { | ||||
| @@ -2822,6 +2831,16 @@ export type VideoCardFieldsFragment = { | ||||
|     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<{ | ||||
| @@ -2846,6 +2865,7 @@ export type GetVideoFeedQuery = { | ||||
|       updatedAt?: any | null; | ||||
|       startTime?: any | null; | ||||
|       endTime?: any | null; | ||||
|       private: boolean; | ||||
|       elapsedTime?: number | null; | ||||
|       tableSize: number; | ||||
|       owner?: { | ||||
| @@ -2864,6 +2884,19 @@ export type GetVideoFeedQuery = { | ||||
|         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"; | ||||
| @@ -2977,12 +3010,14 @@ export type GetShotsWithJustIdsQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
|   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   countRespectsLimit?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type GetShotsWithJustIdsQuery = { | ||||
|   __typename?: "Query"; | ||||
|   getOrderedShots: { | ||||
|     __typename?: "GetShotsResult"; | ||||
|     count?: number | null; | ||||
|     shots: Array<{ __typename?: "ShotGQL"; id: number; videoId: number }>; | ||||
|   }; | ||||
| }; | ||||
| @@ -3281,6 +3316,7 @@ export type GetLoggedInUserQuery = { | ||||
|     activeVideoId?: number | null; | ||||
|     createdAt?: any | null; | ||||
|     updatedAt?: any | null; | ||||
|     videosPrivateByDefault?: boolean | null; | ||||
|   } | null; | ||||
| }; | ||||
|  | ||||
| @@ -3408,6 +3444,25 @@ export type DoesUsernameExistQuery = { | ||||
|   doesUsernameExist: boolean; | ||||
| }; | ||||
|  | ||||
| export type EditUserMutationVariables = Exact<{ | ||||
|   username?: InputMaybe<Scalars["String"]["input"]>; | ||||
|   fargoRating?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   videosPrivateByDefault?: InputMaybe<Scalars["Boolean"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type EditUserMutation = { | ||||
|   __typename?: "Mutation"; | ||||
|   editUser: { | ||||
|     __typename?: "UserGQL"; | ||||
|     id: number; | ||||
|     firebaseUid?: string | null; | ||||
|     username: string; | ||||
|     fargoRating?: number | null; | ||||
|     updatedAt?: any | null; | ||||
|     videosPrivateByDefault?: boolean | null; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetStreamMonitoringDetailsQueryVariables = Exact<{ | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
|   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; | ||||
| @@ -3423,6 +3478,7 @@ export type GetStreamMonitoringDetailsQuery = { | ||||
|     elapsedTime?: number | null; | ||||
|     currentHomography?: { | ||||
|       __typename?: "HomographyInfoGQL"; | ||||
|       frameIndex: number; | ||||
|       crop: { | ||||
|         __typename?: "BoundingBoxGQL"; | ||||
|         left: number; | ||||
| @@ -3837,6 +3893,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; | ||||
| }>; | ||||
| @@ -4026,6 +4146,7 @@ export const VideoCardFieldsFragmentDoc = gql` | ||||
|     updatedAt | ||||
|     startTime | ||||
|     endTime | ||||
|     private | ||||
|     elapsedTime | ||||
|     screenshotUri | ||||
|     stream { | ||||
| @@ -4039,6 +4160,16 @@ export const VideoCardFieldsFragmentDoc = gql` | ||||
|       } | ||||
|       name | ||||
|     } | ||||
|     currentProcessing { | ||||
|       id | ||||
|       errors { | ||||
|         message | ||||
|       } | ||||
|       status | ||||
|       statuses { | ||||
|         status | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export const ShotWithAllFeaturesFragmentDoc = gql` | ||||
| @@ -4159,6 +4290,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) { | ||||
| @@ -4900,12 +5074,15 @@ export const GetShotsWithJustIdsDocument = gql` | ||||
|     $filterInput: FilterInput! | ||||
|     $shotsOrdering: GetShotsOrdering | ||||
|     $limit: Int | ||||
|     $countRespectsLimit: Boolean | ||||
|   ) { | ||||
|     getOrderedShots( | ||||
|       filterInput: $filterInput | ||||
|       shotsOrdering: $shotsOrdering | ||||
|       limit: $limit | ||||
|       countRespectsLimit: $countRespectsLimit | ||||
|     ) { | ||||
|       count | ||||
|       shots { | ||||
|         id | ||||
|         videoId | ||||
| @@ -4929,6 +5106,7 @@ export const GetShotsWithJustIdsDocument = gql` | ||||
|  *      filterInput: // value for 'filterInput' | ||||
|  *      shotsOrdering: // value for 'shotsOrdering' | ||||
|  *      limit: // value for 'limit' | ||||
|  *      countRespectsLimit: // value for 'countRespectsLimit' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| @@ -5372,6 +5550,7 @@ export const GetLoggedInUserDocument = gql` | ||||
|       activeVideoId | ||||
|       createdAt | ||||
|       updatedAt | ||||
|       videosPrivateByDefault | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| @@ -6023,6 +6202,70 @@ export type DoesUsernameExistQueryResult = Apollo.QueryResult< | ||||
|   DoesUsernameExistQuery, | ||||
|   DoesUsernameExistQueryVariables | ||||
| >; | ||||
| export const EditUserDocument = gql` | ||||
|   mutation editUser( | ||||
|     $username: String | ||||
|     $fargoRating: Int | ||||
|     $videosPrivateByDefault: Boolean | ||||
|   ) { | ||||
|     editUser( | ||||
|       input: { | ||||
|         username: $username | ||||
|         fargoRating: $fargoRating | ||||
|         videosPrivateByDefault: $videosPrivateByDefault | ||||
|       } | ||||
|     ) { | ||||
|       id | ||||
|       firebaseUid | ||||
|       username | ||||
|       fargoRating | ||||
|       updatedAt | ||||
|       videosPrivateByDefault | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export type EditUserMutationFn = Apollo.MutationFunction< | ||||
|   EditUserMutation, | ||||
|   EditUserMutationVariables | ||||
| >; | ||||
|  | ||||
| /** | ||||
|  * __useEditUserMutation__ | ||||
|  * | ||||
|  * To run a mutation, you first call `useEditUserMutation` within a React component and pass it any options that fit your needs. | ||||
|  * When your component renders, `useEditUserMutation` 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 [editUserMutation, { data, loading, error }] = useEditUserMutation({ | ||||
|  *   variables: { | ||||
|  *      username: // value for 'username' | ||||
|  *      fargoRating: // value for 'fargoRating' | ||||
|  *      videosPrivateByDefault: // value for 'videosPrivateByDefault' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useEditUserMutation( | ||||
|   baseOptions?: Apollo.MutationHookOptions< | ||||
|     EditUserMutation, | ||||
|     EditUserMutationVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useMutation<EditUserMutation, EditUserMutationVariables>( | ||||
|     EditUserDocument, | ||||
|     options, | ||||
|   ); | ||||
| } | ||||
| export type EditUserMutationHookResult = ReturnType<typeof useEditUserMutation>; | ||||
| export type EditUserMutationResult = Apollo.MutationResult<EditUserMutation>; | ||||
| export type EditUserMutationOptions = Apollo.BaseMutationOptions< | ||||
|   EditUserMutation, | ||||
|   EditUserMutationVariables | ||||
| >; | ||||
| export const GetStreamMonitoringDetailsDocument = gql` | ||||
|   query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | ||||
|     getVideo(videoId: $videoId, debuggingJson: $debuggingJson) { | ||||
| @@ -6031,44 +6274,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 | ||||
| @@ -6089,6 +6295,7 @@ export const GetStreamMonitoringDetailsDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -6538,45 +6745,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 | ||||
| @@ -6593,6 +6762,7 @@ export const GetVideoDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -7026,6 +7196,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) { | ||||
|   | ||||
| @@ -56,6 +56,7 @@ fragment VideoCardFields on VideoGQL { | ||||
|   updatedAt | ||||
|   startTime | ||||
|   endTime | ||||
|   private | ||||
|   elapsedTime | ||||
|   screenshotUri | ||||
|   stream { | ||||
| @@ -69,6 +70,16 @@ fragment VideoCardFields on VideoGQL { | ||||
|     } | ||||
|     name | ||||
|   } | ||||
|   currentProcessing { | ||||
|     id | ||||
|     errors { | ||||
|       message | ||||
|     } | ||||
|     status | ||||
|     statuses { | ||||
|       status | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetVideoFeed( | ||||
|   | ||||
| @@ -66,12 +66,15 @@ query GetShotsWithJustIds( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
|   $limit: Int | ||||
|   $countRespectsLimit: Boolean | ||||
| ) { | ||||
|   getOrderedShots( | ||||
|     filterInput: $filterInput | ||||
|     shotsOrdering: $shotsOrdering | ||||
|     limit: $limit | ||||
|     countRespectsLimit: $countRespectsLimit | ||||
|   ) { | ||||
|     count | ||||
|     shots { | ||||
|       id | ||||
|       videoId | ||||
|   | ||||
| @@ -41,6 +41,7 @@ query getLoggedInUser { | ||||
|     activeVideoId | ||||
|     createdAt | ||||
|     updatedAt | ||||
|     videosPrivateByDefault | ||||
|   } | ||||
| } | ||||
|  | ||||
| @@ -135,3 +136,24 @@ query getUserFollowingFollowers { | ||||
| query doesUsernameExist($candidateUsername: String!) { | ||||
|   doesUsernameExist(candidateUsername: $candidateUsername) | ||||
| } | ||||
|  | ||||
| mutation editUser( | ||||
|   $username: String | ||||
|   $fargoRating: Int | ||||
|   $videosPrivateByDefault: Boolean | ||||
| ) { | ||||
|   editUser( | ||||
|     input: { | ||||
|       username: $username | ||||
|       fargoRating: $fargoRating | ||||
|       videosPrivateByDefault: $videosPrivateByDefault | ||||
|     } | ||||
|   ) { | ||||
|     id | ||||
|     firebaseUid | ||||
|     username | ||||
|     fargoRating | ||||
|     updatedAt | ||||
|     videosPrivateByDefault | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -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 | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -46,7 +46,7 @@ type Query { | ||||
|     limit: Int = 100 | ||||
|     after: String = null | ||||
|   ): UserRelationshipsResult! | ||||
|   getPlayTime(userId: Int!): UserPlayTimeGQL! | ||||
|   getPlayTime(userId: Int!, filters: VideoFilterInput = null): UserPlayTimeGQL! | ||||
|   getUserVideos( | ||||
|     userId: Int = null | ||||
|     limit: Int! = 5 | ||||
| @@ -56,7 +56,6 @@ type Query { | ||||
|   getUserTags: [TagGQL!]! | ||||
|   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! | ||||
|   getVideos(videoIds: [Int!]!): [VideoGQL!]! | ||||
|   checkHomographyIsValid(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||
|   getFeedVideos( | ||||
|     limit: Int! = 5 | ||||
|     after: String = null | ||||
| @@ -401,6 +400,7 @@ type UserGQL { | ||||
|   profileImageUri: String | ||||
|   createdAt: DateTime | ||||
|   updatedAt: DateTime | ||||
|   videosPrivateByDefault: Boolean | ||||
|   following: [UserGQL!] | ||||
|   followers: [UserGQL!] | ||||
| } | ||||
| @@ -438,6 +438,7 @@ type VideoGQL { | ||||
|   elapsedTime: Float | ||||
|   framesPerSecond: Float! | ||||
|   tableSize: Float! | ||||
|   private: Boolean! | ||||
|   stream: UploadStreamGQL | ||||
|   playlist: HLSPlaylistGQL | ||||
|   tags: [VideoTag!]! | ||||
| @@ -510,6 +511,7 @@ type VideoTagClass { | ||||
| } | ||||
|  | ||||
| type HomographyInfoGQL { | ||||
|   id: Int! | ||||
|   frameIndex: Int! | ||||
|   crop: BoundingBoxGQL! | ||||
|   pockets: [BoundingBoxGQL!]! | ||||
| @@ -539,6 +541,7 @@ type IntPoint2D { | ||||
| } | ||||
|  | ||||
| type VideoProcessingGQL { | ||||
|   id: Int! | ||||
|   errors: [VideoProcessingErrorGQL!]! | ||||
|   status: ProcessingStatusEnum! | ||||
|   statuses: [VideoProcessingStatusGQL!]! | ||||
| @@ -621,6 +624,12 @@ type UserPlayTimeGQL { | ||||
|   totalSeconds: Float! | ||||
| } | ||||
|  | ||||
| input VideoFilterInput { | ||||
|   isStreamCompleted: Boolean = null | ||||
|   requireCursorCompletion: Boolean! = true | ||||
|   createdAt: DateRangeFilter = null | ||||
| } | ||||
|  | ||||
| type VideoHistoryGQL { | ||||
|   videos: [VideoGQL!]! | ||||
|   pageInfo: PageInfoGQL! | ||||
| @@ -631,11 +640,6 @@ type PageInfoGQL { | ||||
|   endCursor: String | ||||
| } | ||||
|  | ||||
| input VideoFilterInput { | ||||
|   isStreamCompleted: Boolean = null | ||||
|   requireCursorCompletion: Boolean! = true | ||||
| } | ||||
|  | ||||
| type TagGQL { | ||||
|   name: String! | ||||
|   id: Int! | ||||
| @@ -669,6 +673,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! | ||||
| @@ -757,6 +762,7 @@ type TooManyProfileImageUploadsErr { | ||||
| input EditUserInputGQL { | ||||
|   username: String = null | ||||
|   fargoRating: Int = null | ||||
|   videosPrivateByDefault: Boolean = null | ||||
| } | ||||
|  | ||||
| type CreateUploadStreamReturn { | ||||
| @@ -771,6 +777,7 @@ input VideoMetadataInput { | ||||
|   tableSize: Float = null | ||||
|   lastIntendedSegmentBound: Int = null | ||||
|   streamSegmentType: StreamSegmentTypeEnum = null | ||||
|   private: Boolean = null | ||||
|   endStream: Boolean! = false | ||||
|   resolution: VideoResolution = null | ||||
|   framesPerSecond: Float = null | ||||
|   | ||||
		Reference in New Issue
	
	Block a user