Compare commits
	
		
			1 Commits
		
	
	
		
			8ed177b0f3
			...
			volodymyr/
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5e2fe35427 | 
							
								
								
									
										1166
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										1166
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										69
									
								
								src/operations/check_homography.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/operations/check_homography.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | mutation checkHomographyIsValid($b64Image: String!, $videoId: Int!) { | ||||||
|  |   checkHomographyIsValid(b64Image: $b64Image, videoId: $videoId) { | ||||||
|  |     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 | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     destPoints { | ||||||
|  |       topLeft { | ||||||
|  |         x | ||||||
|  |         y | ||||||
|  |       } | ||||||
|  |       topSide { | ||||||
|  |         x | ||||||
|  |         y | ||||||
|  |       } | ||||||
|  |       topRight { | ||||||
|  |         x | ||||||
|  |         y | ||||||
|  |       } | ||||||
|  |       bottomLeft { | ||||||
|  |         x | ||||||
|  |         y | ||||||
|  |       } | ||||||
|  |       bottomSide { | ||||||
|  |         x | ||||||
|  |         y | ||||||
|  |       } | ||||||
|  |       bottomRight { | ||||||
|  |         x | ||||||
|  |         y | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -6,7 +6,32 @@ query GetFeed( | |||||||
| ) { | ) { | ||||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|     videos { |     videos { | ||||||
|       ...VideoCardFields |       id | ||||||
|  |       owner { | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |       name | ||||||
|  |       screenshotUri | ||||||
|  |       totalShotsMade | ||||||
|  |       totalShots | ||||||
|  |       makePercentage | ||||||
|  |       createdAt | ||||||
|  |       updatedAt | ||||||
|  |       startTime | ||||||
|  |       endTime | ||||||
|  |       elapsedTime | ||||||
|  |       screenshotUri | ||||||
|  |       stream { | ||||||
|  |         id | ||||||
|  |         isCompleted | ||||||
|  |       } | ||||||
|  |       tableSize | ||||||
|  |       tags { | ||||||
|  |         tagClasses { | ||||||
|  |           name | ||||||
|  |         } | ||||||
|  |         name | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|     pageInfo { |     pageInfo { | ||||||
|       hasNextPage |       hasNextPage | ||||||
| @@ -31,7 +56,6 @@ fragment VideoCardFields on VideoGQL { | |||||||
|   updatedAt |   updatedAt | ||||||
|   startTime |   startTime | ||||||
|   endTime |   endTime | ||||||
|   private |  | ||||||
|   elapsedTime |   elapsedTime | ||||||
|   screenshotUri |   screenshotUri | ||||||
|   stream { |   stream { | ||||||
| @@ -46,7 +70,6 @@ fragment VideoCardFields on VideoGQL { | |||||||
|     name |     name | ||||||
|   } |   } | ||||||
|   currentProcessing { |   currentProcessing { | ||||||
|     id |  | ||||||
|     errors { |     errors { | ||||||
|       message |       message | ||||||
|     } |     } | ||||||
| @@ -61,14 +84,8 @@ query GetVideoFeed( | |||||||
|   $limit: Int! = 5 |   $limit: Int! = 5 | ||||||
|   $after: String = null |   $after: String = null | ||||||
|   $filters: VideoFilterInput = null |   $filters: VideoFilterInput = null | ||||||
|   $includeCallersVideos: Boolean = null |  | ||||||
| ) { | ) { | ||||||
|   getFeedVideos( |   getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|     limit: $limit |  | ||||||
|     after: $after |  | ||||||
|     filters: $filters |  | ||||||
|     includeCallersVideos: $includeCallersVideos |  | ||||||
|   ) { |  | ||||||
|     videos { |     videos { | ||||||
|       ...VideoCardFields |       ...VideoCardFields | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,75 +0,0 @@ | |||||||
| fragment MedalFields on MedalGQL { |  | ||||||
|   count |  | ||||||
|   nickname |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query getMedals($scope: MedalScope!, $userId: Int) { |  | ||||||
|   getMedals(scope: $scope, userId: $userId) { |  | ||||||
|     distanceOver78 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     distanceOver90 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength3 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength5 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength8 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength10 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength15 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength20 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength25 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength30 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength40 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength50 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes100 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes500 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes1000 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes5000 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes10000 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes50 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes100 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes150 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes200 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes250 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -66,15 +66,12 @@ query GetShotsWithJustIds( | |||||||
|   $filterInput: FilterInput! |   $filterInput: FilterInput! | ||||||
|   $shotsOrdering: GetShotsOrdering |   $shotsOrdering: GetShotsOrdering | ||||||
|   $limit: Int |   $limit: Int | ||||||
|   $countRespectsLimit: Boolean |  | ||||||
| ) { | ) { | ||||||
|   getOrderedShots( |   getOrderedShots( | ||||||
|     filterInput: $filterInput |     filterInput: $filterInput | ||||||
|     shotsOrdering: $shotsOrdering |     shotsOrdering: $shotsOrdering | ||||||
|     limit: $limit |     limit: $limit | ||||||
|     countRespectsLimit: $countRespectsLimit |  | ||||||
|   ) { |   ) { | ||||||
|     count |  | ||||||
|     shots { |     shots { | ||||||
|       id |       id | ||||||
|       videoId |       videoId | ||||||
| @@ -159,7 +156,6 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|     targetPocketAngleDirection |     targetPocketAngleDirection | ||||||
|     marginOfErrorInDegrees |     marginOfErrorInDegrees | ||||||
|     intendedPocketType |     intendedPocketType | ||||||
|     difficulty |  | ||||||
|   } |   } | ||||||
|   pocketingIntentionInfo { |   pocketingIntentionInfo { | ||||||
|     ballId |     ballId | ||||||
| @@ -178,15 +174,3 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|     notes |     notes | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { |  | ||||||
|   editShot(shotId: $shotId, fieldsToEdit: $fieldsToEdit) { |  | ||||||
|     error { |  | ||||||
|       shotId |  | ||||||
|       msg |  | ||||||
|     } |  | ||||||
|     shot { |  | ||||||
|       ...ShotWithAllFeatures |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -41,12 +41,11 @@ query getLoggedInUser { | |||||||
|     activeVideoId |     activeVideoId | ||||||
|     createdAt |     createdAt | ||||||
|     updatedAt |     updatedAt | ||||||
|     videosPrivateByDefault |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query GetUserPlayTime($userId: Int!, $filters: VideoFilterInput) { | query GetUserPlayTime($userId: Int!) { | ||||||
|   getPlayTime(userId: $userId, filters: $filters) { |   getPlayTime(userId: $userId) { | ||||||
|     totalSeconds |     totalSeconds | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -136,24 +135,3 @@ query getUserFollowingFollowers { | |||||||
| query doesUsernameExist($candidateUsername: String!) { | query doesUsernameExist($candidateUsername: String!) { | ||||||
|   doesUsernameExist(candidateUsername: $candidateUsername) |   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,7 +5,44 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | |||||||
|     makePercentage |     makePercentage | ||||||
|     elapsedTime |     elapsedTime | ||||||
|     currentHomography { |     currentHomography { | ||||||
|       ...HomographyInfo |       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 { |     stream { | ||||||
|       id |       id | ||||||
| @@ -18,7 +55,6 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | |||||||
|       initPlaylistUploadStatus |       initPlaylistUploadStatus | ||||||
|     } |     } | ||||||
|     currentProcessing { |     currentProcessing { | ||||||
|       id |  | ||||||
|       errors { |       errors { | ||||||
|         message |         message | ||||||
|         startSegmentIndex |         startSegmentIndex | ||||||
| @@ -36,7 +72,6 @@ query GetVideoUpdatePageDetails($videoId: Int!) { | |||||||
|     makePercentage |     makePercentage | ||||||
|     elapsedTime |     elapsedTime | ||||||
|     tableSize |     tableSize | ||||||
|     private |  | ||||||
|     tags { |     tags { | ||||||
|       tagClasses { |       tagClasses { | ||||||
|         name |         name | ||||||
| @@ -66,7 +101,6 @@ query GetVideoDetails($videoId: Int!) { | |||||||
|     createdAt |     createdAt | ||||||
|     updatedAt |     updatedAt | ||||||
|     tableSize |     tableSize | ||||||
|     private |  | ||||||
|     owner { |     owner { | ||||||
|       id |       id | ||||||
|       firebaseUid |       firebaseUid | ||||||
| @@ -120,7 +154,45 @@ query GetVideo($videoId: Int!) { | |||||||
|       segmentDurations |       segmentDurations | ||||||
|     } |     } | ||||||
|     homographyHistory { |     homographyHistory { | ||||||
|       ...HomographyInfo |       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 { |     stream { | ||||||
|       id |       id | ||||||
| @@ -216,52 +288,3 @@ query GetHeaderInfoByVideoId($videoId: Int!) { | |||||||
|     startTime |     startTime | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { |  | ||||||
|   findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { |  | ||||||
|     ...HomographyInfo |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment HomographyInfo on HomographyInfoGQL { |  | ||||||
|   id |  | ||||||
|   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 |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|   | |||||||
							
								
								
									
										177
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										177
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -10,13 +10,6 @@ type Query { | |||||||
|     intervalDuration: Int! = 300 |     intervalDuration: Int! = 300 | ||||||
|   ): [MakePercentageIntervalGQL!]! |   ): [MakePercentageIntervalGQL!]! | ||||||
|   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! |   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! | ||||||
|   getRuns( |  | ||||||
|     filterInput: RunFilterInput! |  | ||||||
|     runIds: [Int!] = null |  | ||||||
|     runsOrdering: GetRunsOrdering = null |  | ||||||
|     limit: Int! = 500 |  | ||||||
|     countRespectsLimit: Boolean! = false |  | ||||||
|   ): GetRunsResult! |  | ||||||
|   getOrderedShots( |   getOrderedShots( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     ids: [Int!] = null |     ids: [Int!] = null | ||||||
| @@ -53,7 +46,7 @@ type Query { | |||||||
|     limit: Int = 100 |     limit: Int = 100 | ||||||
|     after: String = null |     after: String = null | ||||||
|   ): UserRelationshipsResult! |   ): UserRelationshipsResult! | ||||||
|   getPlayTime(userId: Int!, filters: VideoFilterInput = null): UserPlayTimeGQL! |   getPlayTime(userId: Int!): UserPlayTimeGQL! | ||||||
|   getUserVideos( |   getUserVideos( | ||||||
|     userId: Int = null |     userId: Int = null | ||||||
|     limit: Int! = 5 |     limit: Int! = 5 | ||||||
| @@ -66,7 +59,6 @@ type Query { | |||||||
|   getFeedVideos( |   getFeedVideos( | ||||||
|     limit: Int! = 5 |     limit: Int! = 5 | ||||||
|     after: String = null |     after: String = null | ||||||
|     includeCallersVideos: Boolean = true |  | ||||||
|     filters: VideoFilterInput = null |     filters: VideoFilterInput = null | ||||||
|   ): VideoHistoryGQL! |   ): VideoHistoryGQL! | ||||||
| } | } | ||||||
| @@ -293,49 +285,42 @@ type RequestedMedalsGQL { | |||||||
|   runLength30: MedalGQL |   runLength30: MedalGQL | ||||||
|   runLength40: MedalGQL |   runLength40: MedalGQL | ||||||
|   runLength50: MedalGQL |   runLength50: MedalGQL | ||||||
|   totalMakes25: MedalGQL @deprecated(reason: "no longer supported") |   totalMakes25: MedalGQL | ||||||
|   totalMakes50: MedalGQL @deprecated(reason: "no longer supported") |   totalMakes50: MedalGQL | ||||||
|   totalMakes75: MedalGQL @deprecated(reason: "no longer supported") |   totalMakes75: MedalGQL | ||||||
|   totalMakes200: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes300: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes400: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes750: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes100: MedalGQL |   totalMakes100: MedalGQL | ||||||
|  |   totalMakes200: MedalGQL | ||||||
|  |   totalMakes300: MedalGQL | ||||||
|  |   totalMakes400: MedalGQL | ||||||
|   totalMakes500: MedalGQL |   totalMakes500: MedalGQL | ||||||
|  |   totalMakes750: MedalGQL | ||||||
|   totalMakes1000: MedalGQL |   totalMakes1000: MedalGQL | ||||||
|   totalMakes5000: MedalGQL |   dayStreak2: MedalGQL | ||||||
|   totalMakes10000: MedalGQL |   dayStreak3: MedalGQL | ||||||
|   dailyMakes50: MedalGQL |   dayStreak4: MedalGQL | ||||||
|   dailyMakes100: MedalGQL |   dayStreak5: MedalGQL | ||||||
|   dailyMakes150: MedalGQL |   dayStreak6: MedalGQL | ||||||
|   dailyMakes200: MedalGQL |   dayStreak7: MedalGQL | ||||||
|   dailyMakes250: MedalGQL |   dayStreak14: MedalGQL | ||||||
|  |   dayStreak21: MedalGQL | ||||||
|  |   dayStreak30: MedalGQL | ||||||
|  |   dayStreak60: MedalGQL | ||||||
|  |   dayStreak90: MedalGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| type MedalGQL { | type MedalGQL { | ||||||
|   count: Int! |   count: Int! | ||||||
|   nickname: String |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input MedalScope @oneOf { | input MedalScope @oneOf { | ||||||
|   videoId: Int |   videoId: Int | ||||||
|   interval: TimeInterval |   interval: TimeInterval | ||||||
|     @deprecated(reason: "NO LONGER SUPPORTED, USE DATETIME_RANGE") |  | ||||||
|   datetimeRange: DatetimeRangeAggregationInput |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type GetRunsResult { | type GetShotsResult { | ||||||
|   runs: [RunGQL!]! |  | ||||||
|   count: Int |  | ||||||
|   runIds: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type RunGQL { |  | ||||||
|   id: Int! |  | ||||||
|   runLength: Int! |  | ||||||
|   videoId: Int! |  | ||||||
|   userId: Int! |  | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|  |   count: Int | ||||||
|  |   ids: [Int!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotGQL { | type ShotGQL { | ||||||
| @@ -415,7 +400,6 @@ type UserGQL { | |||||||
|   profileImageUri: String |   profileImageUri: String | ||||||
|   createdAt: DateTime |   createdAt: DateTime | ||||||
|   updatedAt: DateTime |   updatedAt: DateTime | ||||||
|   videosPrivateByDefault: Boolean |  | ||||||
|   following: [UserGQL!] |   following: [UserGQL!] | ||||||
|   followers: [UserGQL!] |   followers: [UserGQL!] | ||||||
| } | } | ||||||
| @@ -453,7 +437,6 @@ type VideoGQL { | |||||||
|   elapsedTime: Float |   elapsedTime: Float | ||||||
|   framesPerSecond: Float! |   framesPerSecond: Float! | ||||||
|   tableSize: Float! |   tableSize: Float! | ||||||
|   private: Boolean! |  | ||||||
|   stream: UploadStreamGQL |   stream: UploadStreamGQL | ||||||
|   playlist: HLSPlaylistGQL |   playlist: HLSPlaylistGQL | ||||||
|   tags: [VideoTag!]! |   tags: [VideoTag!]! | ||||||
| @@ -476,7 +459,6 @@ type UploadStreamGQL { | |||||||
|   createdAt: DateTime! |   createdAt: DateTime! | ||||||
|   updatedAt: DateTime! |   updatedAt: DateTime! | ||||||
|   segments: [UploadSegmentGQL!]! |   segments: [UploadSegmentGQL!]! | ||||||
|   clientUploadStatus: ClientUploadStatusEnum |  | ||||||
|   resolution: VideoResolutionGQL! |   resolution: VideoResolutionGQL! | ||||||
|   streamSegmentType: StreamSegmentTypeEnum! |   streamSegmentType: StreamSegmentTypeEnum! | ||||||
| } | } | ||||||
| @@ -501,11 +483,6 @@ type UploadSegmentGQL { | |||||||
|   linksRequested: Int! |   linksRequested: Int! | ||||||
| } | } | ||||||
|  |  | ||||||
| enum ClientUploadStatusEnum { |  | ||||||
|   UPLOAD_ENABLED |  | ||||||
|   UPLOAD_DISABLED |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoResolutionGQL { | type VideoResolutionGQL { | ||||||
|   width: Int |   width: Int | ||||||
|   height: Int |   height: Int | ||||||
| @@ -532,7 +509,6 @@ type VideoTagClass { | |||||||
| } | } | ||||||
|  |  | ||||||
| type HomographyInfoGQL { | type HomographyInfoGQL { | ||||||
|   id: Int! |  | ||||||
|   frameIndex: Int! |   frameIndex: Int! | ||||||
|   crop: BoundingBoxGQL! |   crop: BoundingBoxGQL! | ||||||
|   pockets: [BoundingBoxGQL!]! |   pockets: [BoundingBoxGQL!]! | ||||||
| @@ -562,7 +538,6 @@ type IntPoint2D { | |||||||
| } | } | ||||||
|  |  | ||||||
| type VideoProcessingGQL { | type VideoProcessingGQL { | ||||||
|   id: Int! |  | ||||||
|   errors: [VideoProcessingErrorGQL!]! |   errors: [VideoProcessingErrorGQL!]! | ||||||
|   status: ProcessingStatusEnum! |   status: ProcessingStatusEnum! | ||||||
|   statuses: [VideoProcessingStatusGQL!]! |   statuses: [VideoProcessingStatusGQL!]! | ||||||
| @@ -593,62 +568,33 @@ type VideoProcessingStatusGQL { | |||||||
|   updatedAt: DateTime |   updatedAt: DateTime | ||||||
| } | } | ||||||
|  |  | ||||||
| input RunFilterInput { |  | ||||||
|   videoId: [Int!] |  | ||||||
|   userId: [Int!] |  | ||||||
|   username: [String!] |  | ||||||
|   andFilters: [RunFilterInput!] |  | ||||||
|   orFilters: [RunFilterInput!] |  | ||||||
|   notFilter: RunFilterInput |  | ||||||
|   tableSize: FloatRangeFilter |  | ||||||
|   createdAt: DateRangeFilter |  | ||||||
|   runLength: FloatRangeFilter |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input GetRunsOrdering { |  | ||||||
|   orderings: [RunsOrderingComponent!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input RunsOrderingComponent @oneOf { |  | ||||||
|   runLength: IntOrdering |  | ||||||
|   videoId: IntOrdering |  | ||||||
|   videoCreation: DatetimeOrdering |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input IntOrdering { |  | ||||||
|   descending: Boolean! = true |  | ||||||
|   startingAt: Int = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input DatetimeOrdering { |  | ||||||
|   descending: Boolean! = true |  | ||||||
|   startingAt: DateTime = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type GetShotsResult { |  | ||||||
|   shots: [ShotGQL!]! |  | ||||||
|   count: Int |  | ||||||
|   ids: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input GetShotsOrdering { | input GetShotsOrdering { | ||||||
|   orderings: [ShotsOrderingComponent!]! |   orderings: [ShotsOrderingComponent!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| input ShotsOrderingComponent @oneOf { | input ShotsOrderingComponent @oneOf { | ||||||
|   videoCreation: DatetimeOrdering |   videoCreation: DatetimeShotOrdering | ||||||
|   marginOfError: FloatOrdering |   marginOfError: FloatShotOrdering | ||||||
|   difficulty: FloatOrdering |   videoId: IntShotOrdering | ||||||
|   videoId: IntOrdering |   startFrame: IntShotOrdering | ||||||
|   startFrame: IntOrdering |   runLength: IntShotOrdering | ||||||
|   runLength: IntOrdering |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input FloatOrdering { | input DatetimeShotOrdering { | ||||||
|  |   descending: Boolean! = true | ||||||
|  |   startingAt: DateTime = null | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input FloatShotOrdering { | ||||||
|   descending: Boolean! = true |   descending: Boolean! = true | ||||||
|   startingAt: Float = null |   startingAt: Float = null | ||||||
| } | } | ||||||
|  |  | ||||||
|  | input IntShotOrdering { | ||||||
|  |   descending: Boolean! = true | ||||||
|  |   startingAt: Int = null | ||||||
|  | } | ||||||
|  |  | ||||||
| input GetShotsPagination { | input GetShotsPagination { | ||||||
|   createdAfter: CreatedAfter! |   createdAfter: CreatedAfter! | ||||||
|   startFrameAfter: Int! |   startFrameAfter: Int! | ||||||
| @@ -674,13 +620,6 @@ type UserPlayTimeGQL { | |||||||
|   totalSeconds: Float! |   totalSeconds: Float! | ||||||
| } | } | ||||||
|  |  | ||||||
| input VideoFilterInput { |  | ||||||
|   isStreamCompleted: Boolean = null |  | ||||||
|   requireCursorCompletion: Boolean! = true |  | ||||||
|   createdAt: DateRangeFilter = null |  | ||||||
|   excludeVideosWithNoShots: Boolean = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoHistoryGQL { | type VideoHistoryGQL { | ||||||
|   videos: [VideoGQL!]! |   videos: [VideoGQL!]! | ||||||
|   pageInfo: PageInfoGQL! |   pageInfo: PageInfoGQL! | ||||||
| @@ -691,6 +630,11 @@ type PageInfoGQL { | |||||||
|   endCursor: String |   endCursor: String | ||||||
| } | } | ||||||
|  |  | ||||||
|  | input VideoFilterInput { | ||||||
|  |   isStreamCompleted: Boolean = null | ||||||
|  |   requireCursorCompletion: Boolean! = true | ||||||
|  | } | ||||||
|  |  | ||||||
| type TagGQL { | type TagGQL { | ||||||
|   name: String! |   name: String! | ||||||
|   id: Int! |   id: Int! | ||||||
| @@ -708,10 +652,6 @@ scalar JSON | |||||||
| type Mutation { | type Mutation { | ||||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! |   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||||
|   setLoggerLevel(path: String!, level: String!): Boolean! |   setLoggerLevel(path: String!, level: String!): Boolean! | ||||||
|   editShot( |  | ||||||
|     shotId: Int! |  | ||||||
|     fieldsToEdit: EditableShotFieldInputGQL! |  | ||||||
|   ): EditShotReturn! |  | ||||||
|   addAnnotationToShot( |   addAnnotationToShot( | ||||||
|     shotId: Int! |     shotId: Int! | ||||||
|     annotationName: String! |     annotationName: String! | ||||||
| @@ -728,7 +668,7 @@ type Mutation { | |||||||
|   editUser(input: EditUserInputGQL!): UserGQL! |   editUser(input: EditUserInputGQL!): UserGQL! | ||||||
|   followUser(followedUserId: Int!): UserGQL! |   followUser(followedUserId: Int!): UserGQL! | ||||||
|   unfollowUser(followedUserId: Int!): UserGQL! |   unfollowUser(followedUserId: Int!): UserGQL! | ||||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL |   checkHomographyIsValid(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||||
|   createUploadStream( |   createUploadStream( | ||||||
|     videoMetadata: VideoMetadataInput! |     videoMetadata: VideoMetadataInput! | ||||||
|   ): CreateUploadStreamReturn! |   ): CreateUploadStreamReturn! | ||||||
| @@ -749,27 +689,6 @@ input CreateBucketSetInput { | |||||||
|   buckets: [BucketInputGQL!]! |   buckets: [BucketInputGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type EditShotReturn { |  | ||||||
|   shot: ShotGQL |  | ||||||
|   error: DoesNotOwnShotErr |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type DoesNotOwnShotErr { |  | ||||||
|   shotId: Int! |  | ||||||
|   msg: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input EditableShotFieldInputGQL { |  | ||||||
|   intendedPocketType: PocketEnum |  | ||||||
|   shotDirection: ShotDirectionEnum |  | ||||||
|   spinType: SpinTypeEnum |  | ||||||
|   targetPocketAngleDirection: ShotDirectionEnum |  | ||||||
|   make: Boolean |  | ||||||
|   backcut: Boolean |  | ||||||
|   excludeFromStats: Boolean |  | ||||||
|   notes: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type AddShotAnnotationReturn { | type AddShotAnnotationReturn { | ||||||
|   value: SuccessfulAddAddShotAnnotationErrors! |   value: SuccessfulAddAddShotAnnotationErrors! | ||||||
| } | } | ||||||
| @@ -790,6 +709,11 @@ union DoesNotOwnShotErrOtherErrorNeedsNote = | |||||||
|     DoesNotOwnShotErr |     DoesNotOwnShotErr | ||||||
|   | OtherErrorNeedsNote |   | OtherErrorNeedsNote | ||||||
|  |  | ||||||
|  | type DoesNotOwnShotErr { | ||||||
|  |   shotId: Int! | ||||||
|  |   msg: String | ||||||
|  | } | ||||||
|  |  | ||||||
| type OtherErrorNeedsNote { | type OtherErrorNeedsNote { | ||||||
|   msg: String |   msg: String | ||||||
| } | } | ||||||
| @@ -833,7 +757,6 @@ type TooManyProfileImageUploadsErr { | |||||||
| input EditUserInputGQL { | input EditUserInputGQL { | ||||||
|   username: String = null |   username: String = null | ||||||
|   fargoRating: Int = null |   fargoRating: Int = null | ||||||
|   videosPrivateByDefault: Boolean = null |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type CreateUploadStreamReturn { | type CreateUploadStreamReturn { | ||||||
| @@ -848,9 +771,7 @@ input VideoMetadataInput { | |||||||
|   tableSize: Float = null |   tableSize: Float = null | ||||||
|   lastIntendedSegmentBound: Int = null |   lastIntendedSegmentBound: Int = null | ||||||
|   streamSegmentType: StreamSegmentTypeEnum = null |   streamSegmentType: StreamSegmentTypeEnum = null | ||||||
|   private: Boolean = null |  | ||||||
|   endStream: Boolean! = false |   endStream: Boolean! = false | ||||||
|   clientUploadStatus: ClientUploadStatusEnum = null |  | ||||||
|   resolution: VideoResolution = null |   resolution: VideoResolution = null | ||||||
|   framesPerSecond: Float = null |   framesPerSecond: Float = null | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user