Compare commits
	
		
			17 Commits
		
	
	
		
			a4f602d651
			...
			kat/pagina
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8c8dcdd8e1 | |||
| 5085c9af90 | |||
| 85bc743c8e | |||
| b8efa644e3 | |||
| c18628a4ca | |||
| 535e24c9c2 | |||
| 04308b1003 | |||
| 43c626141e | |||
| c49266e4c1 | |||
| 6677b9232f | |||
| 76e792be88 | |||
| 5eac3d9d40 | |||
| 64593f09b7 | |||
| e20b68799f | |||
| 378878967a | |||
| 251ebe7056 | |||
| 615e4d5467 | 
							
								
								
									
										296
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										296
									
								
								src/index.tsx
									
									
									
									
									
								
							| @@ -102,6 +102,10 @@ export type CreateUploadStreamReturn = { | ||||
|   videoId: Scalars["Int"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type CreatedAfter = | ||||
|   | { createdAt: Scalars["DateTime"]["input"]; videoId?: never } | ||||
|   | { createdAt?: never; videoId: Scalars["Int"]["input"] }; | ||||
|  | ||||
| export type CueObjectFeaturesGql = { | ||||
|   __typename?: "CueObjectFeaturesGQL"; | ||||
|   cueBallSpeed?: Maybe<Scalars["Float"]["output"]>; | ||||
| @@ -140,6 +144,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -170,6 +175,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -200,6 +206,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -230,6 +237,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -260,6 +268,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -290,6 +299,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -320,6 +330,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -350,6 +361,7 @@ export type FilterInput = | ||||
|       cueObjectDistance: RangeFilter; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -380,6 +392,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject: RangeFilter; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -410,6 +423,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty: RangeFilter; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -440,6 +454,38 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore: RangeFilter; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
|       isLeftMiss?: never; | ||||
|       isRight?: never; | ||||
|       isRightMiss?: never; | ||||
|       isStraight?: never; | ||||
|       kickAngle?: never; | ||||
|       kickDistance?: never; | ||||
|       make?: never; | ||||
|       notFilter?: never; | ||||
|       orFilters?: never; | ||||
|       shotDirection?: never; | ||||
|       spinType?: never; | ||||
|       tags?: never; | ||||
|       targetPocketDistance?: never; | ||||
|       userId?: never; | ||||
|       videoId?: never; | ||||
|     } | ||||
|   | { | ||||
|       andFilters?: never; | ||||
|       annotations?: never; | ||||
|       bankAngle?: never; | ||||
|       bankDistance?: never; | ||||
|       cueAngleAfterObject?: never; | ||||
|       cueBallSpeed?: never; | ||||
|       cueObjectAngle?: never; | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType: Array<PocketEnum>; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -470,6 +516,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect: Array<Scalars["Boolean"]["input"]>; | ||||
|       isLeft?: never; | ||||
| @@ -500,6 +547,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft: Array<Scalars["Boolean"]["input"]>; | ||||
| @@ -530,6 +578,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -560,6 +609,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -590,6 +640,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -620,6 +671,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -650,6 +702,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -680,6 +733,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -710,6 +764,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -740,6 +795,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -770,6 +826,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -800,6 +857,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -830,6 +888,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -860,6 +919,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -890,6 +950,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -920,6 +981,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -950,6 +1012,7 @@ export type FilterInput = | ||||
|       cueObjectDistance?: never; | ||||
|       cueSpeedAfterObject?: never; | ||||
|       difficulty?: never; | ||||
|       falsePositiveScore?: never; | ||||
|       intendedPocketType?: never; | ||||
|       isDirect?: never; | ||||
|       isLeft?: never; | ||||
| @@ -970,6 +1033,11 @@ export type FilterInput = | ||||
|       videoId: Array<Scalars["Int"]["input"]>; | ||||
|     }; | ||||
|  | ||||
| export type GetShotsPagination = { | ||||
|   createdAfter: CreatedAfter; | ||||
|   startFrameAfter: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type GetUploadLinkReturn = { | ||||
|   __typename?: "GetUploadLinkReturn"; | ||||
|   headers: Array<Maybe<Header>>; | ||||
| @@ -1018,6 +1086,7 @@ export type MakePercentageIntervalGql = { | ||||
|  | ||||
| export type Mutation = { | ||||
|   __typename?: "Mutation"; | ||||
|   addAnnotationToShot: Scalars["Boolean"]["output"]; | ||||
|   createBucketSet: BucketSetGql; | ||||
|   createUploadStream: CreateUploadStreamReturn; | ||||
|   deleteVideo: Scalars["Boolean"]["output"]; | ||||
| @@ -1030,6 +1099,11 @@ export type Mutation = { | ||||
|   setSegmentDuration: Scalars["Boolean"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type MutationAddAnnotationToShotArgs = { | ||||
|   annotationName: Scalars["String"]["input"]; | ||||
|   shotId: Scalars["Int"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type MutationCreateBucketSetArgs = { | ||||
|   params: CreateBucketSetInput; | ||||
| }; | ||||
| @@ -1120,6 +1194,7 @@ export type Query = { | ||||
|   getVideo: VideoGql; | ||||
|   getVideoMakePercentageIntervals: Array<MakePercentageIntervalGql>; | ||||
|   getVideos: Array<VideoGql>; | ||||
|   waitFor: Scalars["Float"]["output"]; | ||||
| }; | ||||
|  | ||||
| export type QueryGetAggregatedShotMetricsArgs = { | ||||
| @@ -1136,6 +1211,8 @@ export type QueryGetPlayTimeArgs = { | ||||
|  | ||||
| export type QueryGetShotsArgs = { | ||||
|   filterInput: FilterInput; | ||||
|   limit?: Scalars["Int"]["input"]; | ||||
|   shotsPagination?: InputMaybe<GetShotsPagination>; | ||||
| }; | ||||
|  | ||||
| export type QueryGetUserArgs = { | ||||
| @@ -1168,8 +1245,13 @@ export type QueryGetVideosArgs = { | ||||
|   videoIds: Array<Scalars["Int"]["input"]>; | ||||
| }; | ||||
|  | ||||
| export type QueryWaitForArgs = { | ||||
|   duration: Scalars["Float"]["input"]; | ||||
| }; | ||||
|  | ||||
| export type RangeFilter = { | ||||
|   greaterThanEqualTo?: InputMaybe<Scalars["Float"]["input"]>; | ||||
|   includeOnNone?: Scalars["Boolean"]["input"]; | ||||
|   lessThan?: InputMaybe<Scalars["Float"]["input"]>; | ||||
| }; | ||||
|  | ||||
| @@ -1211,12 +1293,14 @@ export type ShotGql = { | ||||
|   createdAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||
|   cueObjectFeatures?: Maybe<CueObjectFeaturesGql>; | ||||
|   endFrame: Scalars["Int"]["output"]; | ||||
|   falsePositiveScore?: Maybe<Scalars["Float"]["output"]>; | ||||
|   id: Scalars["Int"]["output"]; | ||||
|   pocketingIntentionFeatures?: Maybe<PocketingIntentionFeaturesGql>; | ||||
|   serializedShotPaths?: Maybe<SerializedShotPathsGql>; | ||||
|   startFrame: Scalars["Int"]["output"]; | ||||
|   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||
|   user?: Maybe<UserGql>; | ||||
|   video?: Maybe<VideoGql>; | ||||
|   videoId: Scalars["Int"]["output"]; | ||||
| }; | ||||
|  | ||||
| @@ -1268,6 +1352,7 @@ export type UploadStreamGql = { | ||||
|   resolution: VideoResolutionGql; | ||||
|   segmentProcessingCursor: Scalars["Int"]["output"]; | ||||
|   segments: Array<UploadSegmentGql>; | ||||
|   streamSegmentType: StreamSegmentTypeEnum; | ||||
|   updatedAt: Scalars["DateTime"]["output"]; | ||||
|   uploadCompletionCursor: Scalars["Int"]["output"]; | ||||
|   uploadsCompleted: Scalars["Int"]["output"]; | ||||
| @@ -1489,6 +1574,8 @@ export type GetVideoMakePercentageIntervalsQuery = { | ||||
|  | ||||
| export type GetShotsQueryVariables = Exact<{ | ||||
|   filterInput: FilterInput; | ||||
|   shotsPagination: GetShotsPagination; | ||||
|   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||
|   includeCreatedAt?: Scalars["Boolean"]["input"]; | ||||
|   includeUpdatedAt?: Scalars["Boolean"]["input"]; | ||||
|   includeCueObjectFeatures?: Scalars["Boolean"]["input"]; | ||||
| @@ -1510,6 +1597,7 @@ export type GetShotsQuery = { | ||||
|     videoId: number; | ||||
|     startFrame: number; | ||||
|     endFrame: number; | ||||
|     falsePositiveScore?: number | null; | ||||
|     createdAt?: any | null; | ||||
|     updatedAt?: any | null; | ||||
|     user?: { __typename?: "UserGQL"; id: number } | null; | ||||
| @@ -1780,14 +1868,47 @@ export type GetVideoQuery = { | ||||
|       __typename?: "HLSPlaylistGQL"; | ||||
|       segmentDurations: Array<number>; | ||||
|     } | null; | ||||
|     homographyHistory: Array<{ | ||||
|       __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 }; | ||||
|       }; | ||||
|     }>; | ||||
|     stream?: { | ||||
|       __typename?: "UploadStreamGQL"; | ||||
|       streamSegmentType: StreamSegmentTypeEnum; | ||||
|       segments: Array<{ | ||||
|         __typename?: "UploadSegmentGQL"; | ||||
|         segmentIndex: number; | ||||
|         endFrameIndex?: number | null; | ||||
|         framesPerSecond?: number | null; | ||||
|       }>; | ||||
|       resolution: { | ||||
|         __typename?: "VideoResolutionGQL"; | ||||
|         width?: number | null; | ||||
|         height?: number | null; | ||||
|       }; | ||||
|     } | null; | ||||
|   }; | ||||
| }; | ||||
| @@ -1827,6 +1948,36 @@ export type GetMedianRunForVideoQuery = { | ||||
|   getVideo: { __typename?: "VideoGQL"; id: number; medianRun?: number | null }; | ||||
| }; | ||||
|  | ||||
| export type GetVideoForClipTimesQueryVariables = Exact<{ | ||||
|   videoId: Scalars["Int"]["input"]; | ||||
| }>; | ||||
|  | ||||
| export type GetVideoForClipTimesQuery = { | ||||
|   __typename?: "Query"; | ||||
|   getVideo: { | ||||
|     __typename?: "VideoGQL"; | ||||
|     id: number; | ||||
|     framesPerSecond: number; | ||||
|     playlist?: { | ||||
|       __typename?: "HLSPlaylistGQL"; | ||||
|       segmentDurations: Array<number>; | ||||
|     } | null; | ||||
|     stream?: { | ||||
|       __typename?: "UploadStreamGQL"; | ||||
|       id: string; | ||||
|       streamSegmentType: StreamSegmentTypeEnum; | ||||
|       segments: Array<{ | ||||
|         __typename?: "UploadSegmentGQL"; | ||||
|         uploaded: boolean; | ||||
|         valid: boolean; | ||||
|         segmentIndex: number; | ||||
|         endFrameIndex?: number | null; | ||||
|         framesPerSecond?: number | null; | ||||
|       }>; | ||||
|     } | null; | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export type CreateUploadStreamMutationVariables = Exact<{ | ||||
|   videoMetadataInput: VideoMetadataInput; | ||||
| }>; | ||||
| @@ -2284,6 +2435,8 @@ export type GetVideoMakePercentageIntervalsQueryResult = Apollo.QueryResult< | ||||
| export const GetShotsDocument = gql` | ||||
|   query GetShots( | ||||
|     $filterInput: FilterInput! | ||||
|     $shotsPagination: GetShotsPagination! | ||||
|     $limit: Int | ||||
|     $includeCreatedAt: Boolean! = false | ||||
|     $includeUpdatedAt: Boolean! = false | ||||
|     $includeCueObjectFeatures: Boolean! = false | ||||
| @@ -2296,7 +2449,11 @@ export const GetShotsDocument = gql` | ||||
|     $includeMake: Boolean! = false | ||||
|     $includeIntendedPocketType: Boolean! = false | ||||
|   ) { | ||||
|     getShots(filterInput: $filterInput) { | ||||
|     getShots( | ||||
|       filterInput: $filterInput | ||||
|       shotsPagination: $shotsPagination | ||||
|       limit: $limit | ||||
|     ) { | ||||
|       id | ||||
|       videoId | ||||
|       startFrame | ||||
| @@ -2304,6 +2461,7 @@ export const GetShotsDocument = gql` | ||||
|       user { | ||||
|         id | ||||
|       } | ||||
|       falsePositiveScore | ||||
|       createdAt @include(if: $includeCreatedAt) | ||||
|       updatedAt @include(if: $includeUpdatedAt) | ||||
|       cueObjectFeatures @include(if: $includeCueObjectFeatures) { | ||||
| @@ -2335,6 +2493,8 @@ export const GetShotsDocument = gql` | ||||
|  * const { data, loading, error } = useGetShotsQuery({ | ||||
|  *   variables: { | ||||
|  *      filterInput: // value for 'filterInput' | ||||
|  *      shotsPagination: // value for 'shotsPagination' | ||||
|  *      limit: // value for 'limit' | ||||
|  *      includeCreatedAt: // value for 'includeCreatedAt' | ||||
|  *      includeUpdatedAt: // value for 'includeUpdatedAt' | ||||
|  *      includeCueObjectFeatures: // value for 'includeCueObjectFeatures' | ||||
| @@ -3253,12 +3413,58 @@ export const GetVideoDocument = gql` | ||||
|       playlist { | ||||
|         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 | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|       stream { | ||||
|         streamSegmentType | ||||
|         segments { | ||||
|           segmentIndex | ||||
|           endFrameIndex | ||||
|           framesPerSecond | ||||
|         } | ||||
|         resolution { | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| @@ -3546,6 +3752,94 @@ export type GetMedianRunForVideoQueryResult = Apollo.QueryResult< | ||||
|   GetMedianRunForVideoQuery, | ||||
|   GetMedianRunForVideoQueryVariables | ||||
| >; | ||||
| export const GetVideoForClipTimesDocument = gql` | ||||
|   query GetVideoForClipTimes($videoId: Int!) { | ||||
|     getVideo(videoId: $videoId) { | ||||
|       id | ||||
|       framesPerSecond | ||||
|       playlist { | ||||
|         segmentDurations | ||||
|       } | ||||
|       stream { | ||||
|         id | ||||
|         streamSegmentType | ||||
|         segments { | ||||
|           uploaded | ||||
|           valid | ||||
|           segmentIndex | ||||
|           endFrameIndex | ||||
|           framesPerSecond | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| `; | ||||
|  | ||||
| /** | ||||
|  * __useGetVideoForClipTimesQuery__ | ||||
|  * | ||||
|  * To run a query within a React component, call `useGetVideoForClipTimesQuery` and pass it any options that fit your needs. | ||||
|  * When your component renders, `useGetVideoForClipTimesQuery` 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 } = useGetVideoForClipTimesQuery({ | ||||
|  *   variables: { | ||||
|  *      videoId: // value for 'videoId' | ||||
|  *   }, | ||||
|  * }); | ||||
|  */ | ||||
| export function useGetVideoForClipTimesQuery( | ||||
|   baseOptions: Apollo.QueryHookOptions< | ||||
|     GetVideoForClipTimesQuery, | ||||
|     GetVideoForClipTimesQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useQuery< | ||||
|     GetVideoForClipTimesQuery, | ||||
|     GetVideoForClipTimesQueryVariables | ||||
|   >(GetVideoForClipTimesDocument, options); | ||||
| } | ||||
| export function useGetVideoForClipTimesLazyQuery( | ||||
|   baseOptions?: Apollo.LazyQueryHookOptions< | ||||
|     GetVideoForClipTimesQuery, | ||||
|     GetVideoForClipTimesQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useLazyQuery< | ||||
|     GetVideoForClipTimesQuery, | ||||
|     GetVideoForClipTimesQueryVariables | ||||
|   >(GetVideoForClipTimesDocument, options); | ||||
| } | ||||
| export function useGetVideoForClipTimesSuspenseQuery( | ||||
|   baseOptions?: Apollo.SuspenseQueryHookOptions< | ||||
|     GetVideoForClipTimesQuery, | ||||
|     GetVideoForClipTimesQueryVariables | ||||
|   >, | ||||
| ) { | ||||
|   const options = { ...defaultOptions, ...baseOptions }; | ||||
|   return Apollo.useSuspenseQuery< | ||||
|     GetVideoForClipTimesQuery, | ||||
|     GetVideoForClipTimesQueryVariables | ||||
|   >(GetVideoForClipTimesDocument, options); | ||||
| } | ||||
| export type GetVideoForClipTimesQueryHookResult = ReturnType< | ||||
|   typeof useGetVideoForClipTimesQuery | ||||
| >; | ||||
| export type GetVideoForClipTimesLazyQueryHookResult = ReturnType< | ||||
|   typeof useGetVideoForClipTimesLazyQuery | ||||
| >; | ||||
| export type GetVideoForClipTimesSuspenseQueryHookResult = ReturnType< | ||||
|   typeof useGetVideoForClipTimesSuspenseQuery | ||||
| >; | ||||
| export type GetVideoForClipTimesQueryResult = Apollo.QueryResult< | ||||
|   GetVideoForClipTimesQuery, | ||||
|   GetVideoForClipTimesQueryVariables | ||||
| >; | ||||
| export const CreateUploadStreamDocument = gql` | ||||
|   mutation CreateUploadStream($videoMetadataInput: VideoMetadataInput!) { | ||||
|     createUploadStream(videoMetadata: $videoMetadataInput) { | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| query GetShots( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsPagination: GetShotsPagination! | ||||
|   $limit: Int | ||||
|   $includeCreatedAt: Boolean! = false | ||||
|   $includeUpdatedAt: Boolean! = false | ||||
|   $includeCueObjectFeatures: Boolean! = false | ||||
| @@ -12,7 +14,11 @@ query GetShots( | ||||
|   $includeMake: Boolean! = false | ||||
|   $includeIntendedPocketType: Boolean! = false | ||||
| ) { | ||||
|   getShots(filterInput: $filterInput) { | ||||
|   getShots( | ||||
|     filterInput: $filterInput | ||||
|     shotsPagination: $shotsPagination | ||||
|     limit: $limit | ||||
|   ) { | ||||
|     id | ||||
|     videoId | ||||
|     startFrame | ||||
| @@ -20,6 +26,7 @@ query GetShots( | ||||
|     user { | ||||
|       id | ||||
|     } | ||||
|     falsePositiveScore | ||||
|     createdAt @include(if: $includeCreatedAt) | ||||
|     updatedAt @include(if: $includeUpdatedAt) | ||||
|     cueObjectFeatures @include(if: $includeCueObjectFeatures) { | ||||
|   | ||||
| @@ -138,12 +138,58 @@ query GetVideo($videoId: Int!) { | ||||
|     playlist { | ||||
|       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 | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     stream { | ||||
|       streamSegmentType | ||||
|       segments { | ||||
|         segmentIndex | ||||
|         endFrameIndex | ||||
|         framesPerSecond | ||||
|       } | ||||
|       resolution { | ||||
|         width | ||||
|         height | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -166,3 +212,24 @@ query GetMedianRunForVideo($videoId: Int!) { | ||||
|     medianRun | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetVideoForClipTimes($videoId: Int!) { | ||||
|   getVideo(videoId: $videoId) { | ||||
|     id | ||||
|     framesPerSecond | ||||
|     playlist { | ||||
|       segmentDurations | ||||
|     } | ||||
|     stream { | ||||
|       id | ||||
|       streamSegmentType | ||||
|       segments { | ||||
|         uploaded | ||||
|         valid | ||||
|         segmentIndex | ||||
|         endFrameIndex | ||||
|         framesPerSecond | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -4,11 +4,16 @@ type Query { | ||||
|   ): [AggregateResultGQL!]! | ||||
|   getBucketSet(keyName: String!): BucketSetGQL | ||||
|   getDeployedConfig: DeployedConfigGQL! | ||||
|   waitFor(duration: Float!): Float! | ||||
|   getVideoMakePercentageIntervals( | ||||
|     videoId: ID! | ||||
|     intervalDuration: Int! = 300 | ||||
|   ): [MakePercentageIntervalGQL!]! | ||||
|   getShots(filterInput: FilterInput!): [ShotGQL!]! | ||||
|   getShots( | ||||
|     filterInput: FilterInput! | ||||
|     shotsPagination: GetShotsPagination = null | ||||
|     limit: Int! = 500 | ||||
|   ): [ShotGQL!]! | ||||
|   getShotAnnotationTypes: [ShotAnnotationTypeGQL!]! | ||||
|   getUser(userId: Int!): UserGQL | ||||
|   getLoggedInUser: UserGQL | ||||
| @@ -98,11 +103,13 @@ input FilterInput @oneOf { | ||||
|   cueAngleAfterObject: RangeFilter | ||||
|   cueSpeedAfterObject: RangeFilter | ||||
|   spinType: [String!] | ||||
|   falsePositiveScore: RangeFilter | ||||
| } | ||||
|  | ||||
| input RangeFilter { | ||||
|   lessThan: Float = null | ||||
|   greaterThanEqualTo: Float = null | ||||
|   includeOnNone: Boolean! = false | ||||
| } | ||||
|  | ||||
| enum PocketEnum { | ||||
| @@ -165,6 +172,8 @@ type ShotGQL { | ||||
|   serializedShotPaths: SerializedShotPathsGQL | ||||
|   user: UserGQL | ||||
|   annotations: [ShotAnnotationGQL!]! | ||||
|   falsePositiveScore: Float | ||||
|   video: VideoGQL | ||||
| } | ||||
|  | ||||
| """ | ||||
| @@ -226,15 +235,6 @@ type ShotAnnotationTypeGQL { | ||||
|   name: String! | ||||
| } | ||||
|  | ||||
| type UserPlayTimeGQL { | ||||
|   totalSeconds: Float! | ||||
| } | ||||
|  | ||||
| type VideoHistoryGQL { | ||||
|   videos: [VideoGQL!]! | ||||
|   pageInfo: PageInfoGQL! | ||||
| } | ||||
|  | ||||
| type VideoGQL { | ||||
|   id: Int! | ||||
|   owner: UserGQL | ||||
| @@ -274,6 +274,7 @@ type UploadStreamGQL { | ||||
|   updatedAt: DateTime! | ||||
|   segments: [UploadSegmentGQL!]! | ||||
|   resolution: VideoResolutionGQL! | ||||
|   streamSegmentType: StreamSegmentTypeEnum! | ||||
| } | ||||
|  | ||||
| enum InitPlaylistUploadStatusEnum { | ||||
| @@ -301,6 +302,11 @@ type VideoResolutionGQL { | ||||
|   height: Int | ||||
| } | ||||
|  | ||||
| enum StreamSegmentTypeEnum { | ||||
|   FRAGMENTED_MP4 | ||||
|   RB_CHUNKED_MP4 | ||||
| } | ||||
|  | ||||
| type HLSPlaylistGQL { | ||||
|   videoId: Int! | ||||
|   m3u8Text: String! | ||||
| @@ -355,6 +361,25 @@ type VideoProcessingErrorGQL { | ||||
|   endSegmentIndex: Int | ||||
| } | ||||
|  | ||||
| input GetShotsPagination { | ||||
|   createdAfter: CreatedAfter! | ||||
|   startFrameAfter: Int! | ||||
| } | ||||
|  | ||||
| input CreatedAfter @oneOf { | ||||
|   videoId: Int | ||||
|   createdAt: DateTime | ||||
| } | ||||
|  | ||||
| type UserPlayTimeGQL { | ||||
|   totalSeconds: Float! | ||||
| } | ||||
|  | ||||
| type VideoHistoryGQL { | ||||
|   videos: [VideoGQL!]! | ||||
|   pageInfo: PageInfoGQL! | ||||
| } | ||||
|  | ||||
| type PageInfoGQL { | ||||
|   hasNextPage: Boolean! | ||||
|   endCursor: String | ||||
| @@ -374,6 +399,7 @@ type TagGQL { | ||||
| type Mutation { | ||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||
|   setLoggerLevel(path: String!, level: String!): Boolean! | ||||
|   addAnnotationToShot(shotId: Int!, annotationName: String!): Boolean! | ||||
|   getProfileImageUploadLink(fileExt: String = ".png"): GetUploadLinkReturn! | ||||
|   editProfileImageUri(profileImageUri: String!): UserGQL! | ||||
|   createUploadStream( | ||||
| @@ -442,11 +468,6 @@ enum DeviceTypeEnum { | ||||
|   BROWSER | ||||
| } | ||||
|  | ||||
| enum StreamSegmentTypeEnum { | ||||
|   FRAGMENTED_MP4 | ||||
|   RB_CHUNKED_MP4 | ||||
| } | ||||
|  | ||||
| input VideoResolution { | ||||
|   width: Int! | ||||
|   height: Int! | ||||
|   | ||||
		Reference in New Issue
	
	Block a user