Compare commits
	
		
			17 Commits
		
	
	
		
			kat/video-
			...
			d5ba9c2ba5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d5ba9c2ba5 | |||
| 73771a263a | |||
| 655e59c43c | |||
| 056120a68a | |||
| bd7ffa7fdb | |||
| ec58923c65 | |||
| 63869cd7ca | |||
| 08ae9611cf | |||
| 4e610b7df2 | |||
| 2d6d3964ad | |||
| 73a58de36e | |||
| dc6f246489 | |||
| c0a3aa97dc | |||
| f4e43b24f2 | |||
| 51ab8320d7 | |||
| f9a00ad3eb | |||
| 998b2ffc8c | 
							
								
								
									
										383
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										383
									
								
								src/index.tsx
									
									
									
									
									
								
							| @@ -1942,6 +1942,7 @@ export type HomographyInfoGql = { | ||||
|   crop: BoundingBoxGql; | ||||
|   destPoints: PocketPointsGql; | ||||
|   frameIndex: Scalars["Int"]["output"]; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   pockets: Array<BoundingBoxGql>; | ||||
|   sourcePoints: PocketPointsGql; | ||||
| }; | ||||
| @@ -2008,6 +2009,7 @@ export type Mutation = { | ||||
|   editProfileImageUri: UserGql; | ||||
|   editUploadStream: Scalars["Boolean"]["output"]; | ||||
|   editUser: UserGql; | ||||
|   findPrerecordTableLayout?: Maybe<HomographyInfoGql>; | ||||
|   followUser: UserGql; | ||||
|   getHlsInitUploadLink: GetUploadLinkReturn; | ||||
|   getProfileImageUploadLink: GetProfileUploadLinkReturn; | ||||
| @@ -2049,6 +2051,11 @@ export type MutationEditUserArgs = { | ||||
|   input: EditUserInputGql; | ||||
| }; | ||||
|  | ||||
| export type MutationFindPrerecordTableLayoutArgs = { | ||||
|   b64Image: Scalars["String"]["input"]; | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type MutationFollowUserArgs = { | ||||
|   followedUserId: Scalars["Int"]["input"]; | ||||
| }; | ||||
| @@ -2658,6 +2665,7 @@ export type VideoProcessingErrorGql = { | ||||
| export type VideoProcessingGql = { | ||||
|   __typename?: "VideoProcessingGQL"; | ||||
|   errors: Array<VideoProcessingErrorGql>; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   status: ProcessingStatusEnum; | ||||
|   statuses: Array<VideoProcessingStatusGql>; | ||||
| }; | ||||
| @@ -2816,6 +2824,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<{ | ||||
| @@ -2858,6 +2876,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"; | ||||
| @@ -2967,6 +2998,20 @@ export type GetShotsWithVideoGqlQuery = { | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetShotsWithJustIdsQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
|   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||
| }>; | ||||
|  | ||||
| export type GetShotsWithJustIdsQuery = { | ||||
|   __typename?: "Query"; | ||||
|   getOrderedShots: { | ||||
|     __typename?: "GetShotsResult"; | ||||
|     shots: Array<{ __typename?: "ShotGQL"; id: number; videoId: number }>; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type GetShotsWithMetadataFilterResultQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
|   shotsOrdering?: InputMaybe<GetShotsOrdering>; | ||||
| @@ -3403,6 +3448,7 @@ export type GetStreamMonitoringDetailsQuery = { | ||||
|     elapsedTime?: number | null; | ||||
|     currentHomography?: { | ||||
|       __typename?: "HomographyInfoGQL"; | ||||
|       frameIndex: number; | ||||
|       crop: { | ||||
|         __typename?: "BoundingBoxGQL"; | ||||
|         left: number; | ||||
| @@ -3817,6 +3863,70 @@ export type GetHeaderInfoByVideoIdQuery = { | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type FindPrerecordTableLayoutMutationVariables = Exact<{ | ||||
|   b64Image: Scalars["String"]["input"]; | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }>; | ||||
|  | ||||
| export type FindPrerecordTableLayoutMutation = { | ||||
|   __typename?: "Mutation"; | ||||
|   findPrerecordTableLayout?: { | ||||
|     __typename?: "HomographyInfoGQL"; | ||||
|     frameIndex: number; | ||||
|     crop: { | ||||
|       __typename?: "BoundingBoxGQL"; | ||||
|       left: number; | ||||
|       top: number; | ||||
|       width: number; | ||||
|       height: number; | ||||
|     }; | ||||
|     pockets: Array<{ | ||||
|       __typename?: "BoundingBoxGQL"; | ||||
|       left: number; | ||||
|       top: number; | ||||
|       width: number; | ||||
|       height: number; | ||||
|     }>; | ||||
|     sourcePoints: { | ||||
|       __typename?: "PocketPointsGQL"; | ||||
|       topLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       topSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       topRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       bottomLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       bottomSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|       bottomRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     }; | ||||
|   } | null; | ||||
| }; | ||||
|  | ||||
| export type HomographyInfoFragment = { | ||||
|   __typename?: "HomographyInfoGQL"; | ||||
|   frameIndex: number; | ||||
|   crop: { | ||||
|     __typename?: "BoundingBoxGQL"; | ||||
|     left: number; | ||||
|     top: number; | ||||
|     width: number; | ||||
|     height: number; | ||||
|   }; | ||||
|   pockets: Array<{ | ||||
|     __typename?: "BoundingBoxGQL"; | ||||
|     left: number; | ||||
|     top: number; | ||||
|     width: number; | ||||
|     height: number; | ||||
|   }>; | ||||
|   sourcePoints: { | ||||
|     __typename?: "PocketPointsGQL"; | ||||
|     topLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     topSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     topRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     bottomLeft: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     bottomSide: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|     bottomRight: { __typename?: "IntPoint2D"; x: number; y: number }; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type CreateUploadStreamMutationVariables = Exact<{ | ||||
|   videoMetadataInput: VideoMetadataInput; | ||||
| }>; | ||||
| @@ -4019,6 +4129,16 @@ export const VideoCardFieldsFragmentDoc = gql` | ||||
|       } | ||||
|       name | ||||
|     } | ||||
|     currentProcessing { | ||||
|       id | ||||
|       errors { | ||||
|         message | ||||
|       } | ||||
|       status | ||||
|       statuses { | ||||
|         status | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export const ShotWithAllFeaturesFragmentDoc = gql` | ||||
| @@ -4139,6 +4259,49 @@ export const VideoDurationDataFragmentDoc = gql` | ||||
|   ${PlaylistWithSegmentStartTimesFragmentDoc} | ||||
|   ${StreamWithEndFramesFragmentDoc} | ||||
| `; | ||||
| export const HomographyInfoFragmentDoc = gql` | ||||
|   fragment HomographyInfo on HomographyInfoGQL { | ||||
|     frameIndex | ||||
|     crop { | ||||
|       left | ||||
|       top | ||||
|       width | ||||
|       height | ||||
|     } | ||||
|     pockets { | ||||
|       left | ||||
|       top | ||||
|       width | ||||
|       height | ||||
|     } | ||||
|     sourcePoints { | ||||
|       topLeft { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       topSide { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       topRight { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       bottomLeft { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       bottomSide { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|       bottomRight { | ||||
|         x | ||||
|         y | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
| export const GetAggregatedShotMetricsDocument = gql` | ||||
|   query GetAggregatedShotMetrics($aggregateInput: AggregateInputGQL!) { | ||||
|     getAggregatedShotMetrics(aggregateInput: $aggregateInput) { | ||||
| @@ -4875,6 +5038,92 @@ export type GetShotsWithVideoGqlQueryResult = Apollo.QueryResult< | ||||
|   GetShotsWithVideoGqlQuery, | ||||
|   GetShotsWithVideoGqlQueryVariables | ||||
| >; | ||||
| export const GetShotsWithJustIdsDocument = gql` | ||||
|   query GetShotsWithJustIds( | ||||
|     $filterInput: FilterInput! | ||||
|     $shotsOrdering: GetShotsOrdering | ||||
|     $limit: Int | ||||
|   ) { | ||||
|     getOrderedShots( | ||||
|       filterInput: $filterInput | ||||
|       shotsOrdering: $shotsOrdering | ||||
|       limit: $limit | ||||
|     ) { | ||||
|       shots { | ||||
|         id | ||||
|         videoId | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
|  | ||||
| /** | ||||
|  * __useGetShotsWithJustIdsQuery__ | ||||
|  * | ||||
|  * To run a query within a React component, call `useGetShotsWithJustIdsQuery` and pass it any options that fit your needs. | ||||
|  * When your component renders, `useGetShotsWithJustIdsQuery` returns an object from Apollo Client that contains loading, error, and data properties | ||||
|  * you can use to render your UI. | ||||
|  * | ||||
|  * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options; | ||||
|  * | ||||
|  * @example | ||||
|  * const { data, loading, error } = useGetShotsWithJustIdsQuery({ | ||||
|  *   variables: { | ||||
|  *      filterInput: // value for 'filterInput' | ||||
|  *      shotsOrdering: // value for 'shotsOrdering' | ||||
|  *      limit: // value for 'limit' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useGetShotsWithJustIdsQuery( | ||||
|   baseOptions: Apollo.QueryHookOptions< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useQuery< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >(GetShotsWithJustIdsDocument, options); | ||||
| } | ||||
| export function useGetShotsWithJustIdsLazyQuery( | ||||
|   baseOptions?: Apollo.LazyQueryHookOptions< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useLazyQuery< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >(GetShotsWithJustIdsDocument, options); | ||||
| } | ||||
| export function useGetShotsWithJustIdsSuspenseQuery( | ||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useSuspenseQuery< | ||||
|     GetShotsWithJustIdsQuery, | ||||
|     GetShotsWithJustIdsQueryVariables | ||||
|   >(GetShotsWithJustIdsDocument, options); | ||||
| } | ||||
| export type GetShotsWithJustIdsQueryHookResult = ReturnType< | ||||
|   typeof useGetShotsWithJustIdsQuery | ||||
| >; | ||||
| export type GetShotsWithJustIdsLazyQueryHookResult = ReturnType< | ||||
|   typeof useGetShotsWithJustIdsLazyQuery | ||||
| >; | ||||
| export type GetShotsWithJustIdsSuspenseQueryHookResult = ReturnType< | ||||
|   typeof useGetShotsWithJustIdsSuspenseQuery | ||||
| >; | ||||
| export type GetShotsWithJustIdsQueryResult = Apollo.QueryResult< | ||||
|   GetShotsWithJustIdsQuery, | ||||
|   GetShotsWithJustIdsQueryVariables | ||||
| >; | ||||
| export const GetShotsWithMetadataFilterResultDocument = gql` | ||||
|   query GetShotsWithMetadataFilterResult( | ||||
|     $filterInput: FilterInput! | ||||
| @@ -5925,44 +6174,7 @@ export const GetStreamMonitoringDetailsDocument = gql` | ||||
|       makePercentage | ||||
|       elapsedTime | ||||
|       currentHomography { | ||||
|         crop { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         pockets { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         sourcePoints { | ||||
|           topLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|         } | ||||
|         ...HomographyInfo | ||||
|       } | ||||
|       stream { | ||||
|         id | ||||
| @@ -5983,6 +6195,7 @@ export const GetStreamMonitoringDetailsDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -6432,45 +6645,7 @@ export const GetVideoDocument = gql` | ||||
|         segmentDurations | ||||
|       } | ||||
|       homographyHistory { | ||||
|         frameIndex | ||||
|         crop { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         pockets { | ||||
|           left | ||||
|           top | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|         sourcePoints { | ||||
|           topLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           topRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomLeft { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomSide { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|           bottomRight { | ||||
|             x | ||||
|             y | ||||
|           } | ||||
|         } | ||||
|         ...HomographyInfo | ||||
|       } | ||||
|       stream { | ||||
|         id | ||||
| @@ -6487,6 +6662,7 @@ export const GetVideoDocument = gql` | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
|  | ||||
| /** | ||||
| @@ -6920,6 +7096,59 @@ export type GetHeaderInfoByVideoIdQueryResult = Apollo.QueryResult< | ||||
|   GetHeaderInfoByVideoIdQuery, | ||||
|   GetHeaderInfoByVideoIdQueryVariables | ||||
| >; | ||||
| export const FindPrerecordTableLayoutDocument = gql` | ||||
|   mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | ||||
|     findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { | ||||
|       ...HomographyInfo | ||||
|     } | ||||
|   } | ||||
|   ${HomographyInfoFragmentDoc} | ||||
| `; | ||||
| export type FindPrerecordTableLayoutMutationFn = Apollo.MutationFunction< | ||||
|   FindPrerecordTableLayoutMutation, | ||||
|   FindPrerecordTableLayoutMutationVariables | ||||
| >; | ||||
|  | ||||
| /** | ||||
|  * __useFindPrerecordTableLayoutMutation__ | ||||
|  * | ||||
|  * To run a mutation, you first call `useFindPrerecordTableLayoutMutation` within a React component and pass it any options that fit your needs. | ||||
|  * When your component renders, `useFindPrerecordTableLayoutMutation` returns a tuple that includes: | ||||
|  * - A mutate function that you can call at any time to execute the mutation | ||||
|  * - An object with fields that represent the current status of the mutation's execution | ||||
|  * | ||||
|  * @param baseOptions options that will be passed into the mutation, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options-2; | ||||
|  * | ||||
|  * @example | ||||
|  * const [findPrerecordTableLayoutMutation, { data, loading, error }] = useFindPrerecordTableLayoutMutation({ | ||||
|  *   variables: { | ||||
|  *      b64Image: // value for 'b64Image' | ||||
|  *      videoId: // value for 'videoId' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useFindPrerecordTableLayoutMutation( | ||||
|   baseOptions?: Apollo.MutationHookOptions< | ||||
|     FindPrerecordTableLayoutMutation, | ||||
|     FindPrerecordTableLayoutMutationVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useMutation< | ||||
|     FindPrerecordTableLayoutMutation, | ||||
|     FindPrerecordTableLayoutMutationVariables | ||||
|   >(FindPrerecordTableLayoutDocument, options); | ||||
| } | ||||
| export type FindPrerecordTableLayoutMutationHookResult = ReturnType< | ||||
|   typeof useFindPrerecordTableLayoutMutation | ||||
| >; | ||||
| export type FindPrerecordTableLayoutMutationResult = | ||||
|   Apollo.MutationResult<FindPrerecordTableLayoutMutation>; | ||||
| export type FindPrerecordTableLayoutMutationOptions = | ||||
|   Apollo.BaseMutationOptions< | ||||
|     FindPrerecordTableLayoutMutation, | ||||
|     FindPrerecordTableLayoutMutationVariables | ||||
|   >; | ||||
| export const CreateUploadStreamDocument = gql` | ||||
|   mutation CreateUploadStream($videoMetadataInput: VideoMetadataInput!) { | ||||
|     createUploadStream(videoMetadata: $videoMetadataInput) { | ||||
|   | ||||
| @@ -69,6 +69,16 @@ fragment VideoCardFields on VideoGQL { | ||||
|     } | ||||
|     name | ||||
|   } | ||||
|   currentProcessing { | ||||
|     id | ||||
|     errors { | ||||
|       message | ||||
|     } | ||||
|     status | ||||
|     statuses { | ||||
|       status | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetVideoFeed( | ||||
|   | ||||
| @@ -40,6 +40,7 @@ mutation UpdateShotAnnotations( | ||||
|   } | ||||
| } | ||||
|  | ||||
| ## Should be deprecated | ||||
| query GetShotsWithVideoGql( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
| @@ -61,6 +62,23 @@ query GetShotsWithVideoGql( | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetShotsWithJustIds( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
|   $limit: Int | ||||
| ) { | ||||
|   getOrderedShots( | ||||
|     filterInput: $filterInput | ||||
|     shotsOrdering: $shotsOrdering | ||||
|     limit: $limit | ||||
|   ) { | ||||
|     shots { | ||||
|       id | ||||
|       videoId | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| ## Reserved for playlists (which are created from a filter) | ||||
| query GetShotsWithMetadataFilterResult( | ||||
|   $filterInput: FilterInput! | ||||
|   | ||||
| @@ -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 | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -509,6 +509,7 @@ type VideoTagClass { | ||||
| } | ||||
|  | ||||
| type HomographyInfoGQL { | ||||
|   id: Int! | ||||
|   frameIndex: Int! | ||||
|   crop: BoundingBoxGQL! | ||||
|   pockets: [BoundingBoxGQL!]! | ||||
| @@ -538,6 +539,7 @@ type IntPoint2D { | ||||
| } | ||||
|  | ||||
| type VideoProcessingGQL { | ||||
|   id: Int! | ||||
|   errors: [VideoProcessingErrorGQL!]! | ||||
|   status: ProcessingStatusEnum! | ||||
|   statuses: [VideoProcessingStatusGQL!]! | ||||
| @@ -668,6 +670,7 @@ type Mutation { | ||||
|   editUser(input: EditUserInputGQL!): UserGQL! | ||||
|   followUser(followedUserId: Int!): UserGQL! | ||||
|   unfollowUser(followedUserId: Int!): UserGQL! | ||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||
|   createUploadStream( | ||||
|     videoMetadata: VideoMetadataInput! | ||||
|   ): CreateUploadStreamReturn! | ||||
|   | ||||
		Reference in New Issue
	
	Block a user