Compare commits
	
		
			86 Commits
		
	
	
		
			33886b4e9e
			...
			ivan/remov
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| cfffa3f640 | |||
| 2459cb78f8 | |||
| 8859ad8951 | |||
| bdc3961e46 | |||
| 7c8c932a78 | |||
| ae746ccac0 | |||
| 98266c7775 | |||
|  | 4918720ae3 | ||
| 8463ebf0e7 | |||
| 753179ca58 | |||
| 9ee5c721c1 | |||
| 00cca10cb3 | |||
| ad704cad75 | |||
| e2743abb59 | |||
| e109e89a40 | |||
| 67bad20d24 | |||
| 0160455b9f | |||
| 170ff70b7a | |||
| 8df09b8c93 | |||
| 644ea66e98 | |||
| 0a5097c5c0 | |||
| f4445f7ecb | |||
| b18fedae8e | |||
| 31baa2b096 | |||
| 85cd37f70f | |||
| b53aa172fa | |||
| df2e534745 | |||
|  | ea4980947f | ||
| 65475bca9b | |||
| 280f5a66bd | |||
| 84daf2d136 | |||
| 6558fb60e9 | |||
| 6462a6a464 | |||
| 41a5bb7609 | |||
| b8aaabea8b | |||
| 2745521664 | |||
| 8efa2e067c | |||
| 919fe5ba24 | |||
| 7ff60dc9c5 | |||
| 7e0d8a84ee | |||
| 9f26b5aa0f | |||
| 70303b9363 | |||
| 9ee1422d3e | |||
| 7a9d2545c4 | |||
| c561ea20ab | |||
| 7ce0c058b7 | |||
| c399edd882 | |||
| 32d8cb0d41 | |||
| 9d912ed21e | |||
| 0bcfd32b14 | |||
| 9b27d288da | |||
| b0f94f5ea8 | |||
| de653ba54c | |||
| 2657628a54 | |||
| cd20cfcb40 | |||
| 2657a9baf7 | |||
| 9bb4b7c513 | |||
| a5050ed08d | |||
| b9e26243e9 | |||
| 021cd35278 | |||
| 8dda81236a | |||
| c7ff615fe4 | |||
| 365cbb5f70 | |||
| 194d0dcd22 | |||
| 8fcaa1397a | |||
| e8e318b919 | |||
| ff0a11ea0d | |||
| 84192d1387 | |||
| f1ae2b62d6 | |||
| 4f78cd94ab | |||
| bfdda67d1a | |||
| 881350619a | |||
| 8bc67f75b0 | |||
| df8495df77 | |||
| 0c45855f7d | |||
| a2e659dfcb | |||
| 2a36a392ce | |||
| 145c2f9558 | |||
| 3f2e5d331f | |||
| bf8e851139 | |||
| eb15f4f3b8 | |||
| 82ff8546d4 | |||
| 284334606d | |||
| a883bc3e2f | |||
| b50ea5b573 | |||
| de17659dbb | 
| @@ -12,7 +12,7 @@ | |||||||
|   "author": "Ivan Malison <IvanMalison@gmail.com>", |   "author": "Ivan Malison <IvanMalison@gmail.com>", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@apollo/client": "^3.9.2", |     "@apollo/client": "^3.11.10", | ||||||
|     "@graphql-codegen/cli": "^5.0.0", |     "@graphql-codegen/cli": "^5.0.0", | ||||||
|     "@graphql-codegen/typescript": "^4.0.1", |     "@graphql-codegen/typescript": "^4.0.1", | ||||||
|     "@graphql-codegen/typescript-operations": "^4.0.1", |     "@graphql-codegen/typescript-operations": "^4.0.1", | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ packages = [{include = "rbproto"}] | |||||||
|  |  | ||||||
| [tool.poetry.dependencies] | [tool.poetry.dependencies] | ||||||
| python = ">=3.10,<=3.13" | python = ">=3.10,<=3.13" | ||||||
| protobuf = "^4.25.3" | protobuf = "*" | ||||||
|  |  | ||||||
|  |  | ||||||
| [build-system] | [build-system] | ||||||
|   | |||||||
| @@ -1,9 +1,16 @@ | |||||||
| # see: https://www.apollographql.com/docs/react/local-state/managing-state-with-field-policies/ | # see: https://www.apollographql.com/docs/react/local-state/managing-state-with-field-policies/ | ||||||
| directive @client on FIELD | directive @client on FIELD | ||||||
|  |  | ||||||
|  | type SegmentInfo { | ||||||
|  |   index: Int! | ||||||
|  |   time: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
| extend type ShotGQL { | extend type ShotGQL { | ||||||
|   startTime: Float! |   startTime: Float! | ||||||
|   endTime: Float! |   endTime: Float! | ||||||
|  |   startSegment: SegmentInfo! | ||||||
|  |   endSegment: SegmentInfo! | ||||||
| } | } | ||||||
|  |  | ||||||
| extend type UploadStreamGQL { | extend type UploadStreamGQL { | ||||||
|   | |||||||
							
								
								
									
										2001
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										2001
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										19
									
								
								src/operations/comments.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								src/operations/comments.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | mutation CommentOnVideo( | ||||||
|  |   $videoId: Int! | ||||||
|  |   $message: String! | ||||||
|  |   $parentCommentId: Int | ||||||
|  | ) { | ||||||
|  |   commentOnVideo( | ||||||
|  |     videoId: $videoId | ||||||
|  |     message: $message | ||||||
|  |     parentCommentId: $parentCommentId | ||||||
|  |   ) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation EditComment($videoId: Int!, $commentId: Int!, $newMessage: String!) { | ||||||
|  |   editComment(videoId: $videoId, commentId: $commentId, newMessage: $newMessage) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation DeleteComment($videoId: Int!, $commentId: Int!) { | ||||||
|  |   deleteComment(videoId: $videoId, commentId: $commentId) | ||||||
|  | } | ||||||
| @@ -15,6 +15,17 @@ query GetFeed( | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | fragment UserSocialsFields on UserGQL { | ||||||
|  |   id | ||||||
|  |   username | ||||||
|  |   profileImageUri | ||||||
|  |   followers { | ||||||
|  |     id | ||||||
|  |     username | ||||||
|  |     profileImageUri | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| fragment VideoCardFields on VideoGQL { | fragment VideoCardFields on VideoGQL { | ||||||
|   id |   id | ||||||
|   owner { |   owner { | ||||||
| @@ -27,6 +38,8 @@ fragment VideoCardFields on VideoGQL { | |||||||
|   totalShotsMade |   totalShotsMade | ||||||
|   totalShots |   totalShots | ||||||
|   makePercentage |   makePercentage | ||||||
|  |   averageTimeBetweenShots | ||||||
|  |   averageDifficulty | ||||||
|   createdAt |   createdAt | ||||||
|   updatedAt |   updatedAt | ||||||
|   startTime |   startTime | ||||||
| @@ -36,7 +49,9 @@ fragment VideoCardFields on VideoGQL { | |||||||
|   screenshotUri |   screenshotUri | ||||||
|   stream { |   stream { | ||||||
|     id |     id | ||||||
|  |     lastIntendedSegmentBound | ||||||
|     isCompleted |     isCompleted | ||||||
|  |     streamSegmentType | ||||||
|   } |   } | ||||||
|   tableSize |   tableSize | ||||||
|   tags { |   tags { | ||||||
| @@ -55,6 +70,27 @@ fragment VideoCardFields on VideoGQL { | |||||||
|       status |       status | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |   reactions { | ||||||
|  |     videoId | ||||||
|  |     user { | ||||||
|  |       ...UserSocialsFields | ||||||
|  |     } | ||||||
|  |     reaction | ||||||
|  |   } | ||||||
|  |   comments { | ||||||
|  |     id | ||||||
|  |     message | ||||||
|  |     user { | ||||||
|  |       ...UserSocialsFields | ||||||
|  |     } | ||||||
|  |     replies { | ||||||
|  |       id | ||||||
|  |       message | ||||||
|  |       user { | ||||||
|  |         ...UserSocialsFields | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query GetVideoFeed( | query GetVideoFeed( | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								src/operations/leaderboards.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/operations/leaderboards.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | query GetMakesLeaderboard($interval: TimeInterval, $when: DateTime) { | ||||||
|  |   getMakesLeaderboard(interval: $interval, when: $when) { | ||||||
|  |     entries { | ||||||
|  |       user { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |         profileImageUri | ||||||
|  |       } | ||||||
|  |       value | ||||||
|  |       proportionMade | ||||||
|  |       total | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetRunsLeaderboard($interval: TimeInterval, $when: DateTime) { | ||||||
|  |   getLongestRunsLeaderboard(interval: $interval, when: $when) { | ||||||
|  |     entries { | ||||||
|  |       id | ||||||
|  |       runLength | ||||||
|  |       video { | ||||||
|  |         name | ||||||
|  |         createdAt | ||||||
|  |       } | ||||||
|  |       user { | ||||||
|  |         id | ||||||
|  |         username | ||||||
|  |         profileImageUri | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										3
									
								
								src/operations/reactions.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								src/operations/reactions.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | mutation ReactToVideo($videoId: Int!, $reaction: ReactionEnum) { | ||||||
|  |   reactToVideo(videoId: $videoId, reaction: $reaction) | ||||||
|  | } | ||||||
							
								
								
									
										67
									
								
								src/operations/runs.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								src/operations/runs.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | query GetRunsForHighlights( | ||||||
|  |   $filterInput: RunFilterInput! | ||||||
|  |   $runIds: [Int!] = null | ||||||
|  |   $runsOrdering: GetRunsOrdering | ||||||
|  |   $limit: Int! = 500 | ||||||
|  |   $countRespectsLimit: Boolean! = false | ||||||
|  | ) { | ||||||
|  |   getRuns( | ||||||
|  |     filterInput: $filterInput | ||||||
|  |     runIds: $runIds | ||||||
|  |     runsOrdering: $runsOrdering | ||||||
|  |     limit: $limit | ||||||
|  |     countRespectsLimit: $countRespectsLimit | ||||||
|  |   ) { | ||||||
|  |     count | ||||||
|  |     runs { | ||||||
|  |       id | ||||||
|  |       runLength | ||||||
|  |       userId | ||||||
|  |       videoId | ||||||
|  |       shots { | ||||||
|  |         videoId | ||||||
|  |         id | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     runIds | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fragment PocketingIntentionFragment on PocketingIntentionFeaturesGQL { | ||||||
|  |   make | ||||||
|  |   targetPocketDistance | ||||||
|  |   targetPocketAngle | ||||||
|  |   targetPocketAngleDirection | ||||||
|  |   marginOfErrorInDegrees | ||||||
|  |   intendedPocketType | ||||||
|  |   difficulty | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetRunsWithTimestamps( | ||||||
|  |   $filterInput: RunFilterInput! | ||||||
|  |   $runIds: [Int!] = null | ||||||
|  |   $runsOrdering: GetRunsOrdering | ||||||
|  | ) { | ||||||
|  |   getRuns( | ||||||
|  |     filterInput: $filterInput | ||||||
|  |     runIds: $runIds | ||||||
|  |     runsOrdering: $runsOrdering | ||||||
|  |   ) { | ||||||
|  |     count | ||||||
|  |     runs { | ||||||
|  |       id | ||||||
|  |       runLength | ||||||
|  |       userId | ||||||
|  |       videoId | ||||||
|  |       shots { | ||||||
|  |         videoId | ||||||
|  |         id | ||||||
|  |         createdAt | ||||||
|  |         pocketingIntentionFeatures { | ||||||
|  |           ...PocketingIntentionFragment | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     runIds | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -139,6 +139,14 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|   endFrame |   endFrame | ||||||
|   startTime @client |   startTime @client | ||||||
|   endTime @client |   endTime @client | ||||||
|  |   startSegment @client { | ||||||
|  |     index | ||||||
|  |     time | ||||||
|  |   } | ||||||
|  |   endSegment @client { | ||||||
|  |     index | ||||||
|  |     time | ||||||
|  |   } | ||||||
|   user { |   user { | ||||||
|     id |     id | ||||||
|   } |   } | ||||||
| @@ -177,6 +185,13 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|     } |     } | ||||||
|     notes |     notes | ||||||
|   } |   } | ||||||
|  |   video { | ||||||
|  |     id | ||||||
|  |     stream { | ||||||
|  |       id | ||||||
|  |       streamSegmentType | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { | mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								src/operations/tags.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/operations/tags.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | mutation RetireTags($tagIds: [Int!]!) { | ||||||
|  |   retireTags(tagIds: $tagIds) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation DeleteTags($videoId: Int!, $tagsToDelete: [VideoTagInput!]!) { | ||||||
|  |   deleteTags(videoId: $videoId, tagsToDelete: $tagsToDelete) | ||||||
|  | } | ||||||
| @@ -21,27 +21,19 @@ mutation getProfileImageUploadLink($fileExt: String = ".png") { | |||||||
|  |  | ||||||
| mutation editProfileImageUri($profileImageUri: String!) { | mutation editProfileImageUri($profileImageUri: String!) { | ||||||
|   editProfileImageUri(profileImageUri: $profileImageUri) { |   editProfileImageUri(profileImageUri: $profileImageUri) { | ||||||
|     id |     ...UserFragment | ||||||
|     firebaseUid |  | ||||||
|     username |  | ||||||
|     profileImageUri |  | ||||||
|     createdAt |  | ||||||
|     updatedAt |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query getLoggedInUser { | query getLoggedInUser { | ||||||
|   getLoggedInUser { |   getLoggedInUser { | ||||||
|     id |     ...UserFragment | ||||||
|     firebaseUid |   } | ||||||
|     username | } | ||||||
|     isAdmin |  | ||||||
|     profileImageUri | query GetUser($userId: Int!) { | ||||||
|     fargoRating |   getUser(userId: $userId) { | ||||||
|     activeVideoId |     ...UserFragment | ||||||
|     createdAt |  | ||||||
|     updatedAt |  | ||||||
|     videosPrivateByDefault |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -74,6 +66,7 @@ query getUserRelationshipsMatching( | |||||||
|     relationships { |     relationships { | ||||||
|       toUser { |       toUser { | ||||||
|         username |         username | ||||||
|  |         profileImageUri | ||||||
|         id |         id | ||||||
|       } |       } | ||||||
|       toUserFollows |       toUserFollows | ||||||
| @@ -86,6 +79,10 @@ query GetUserTags { | |||||||
|   getUserTags { |   getUserTags { | ||||||
|     id |     id | ||||||
|     name |     name | ||||||
|  |     tagClasses { | ||||||
|  |       id | ||||||
|  |       name | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -125,10 +122,12 @@ query getUserFollowingFollowers { | |||||||
|     following { |     following { | ||||||
|       id |       id | ||||||
|       username |       username | ||||||
|  |       profileImageUri | ||||||
|     } |     } | ||||||
|     followers { |     followers { | ||||||
|       id |       id | ||||||
|       username |       username | ||||||
|  |       profileImageUri | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -157,3 +156,16 @@ mutation editUser( | |||||||
|     videosPrivateByDefault |     videosPrivateByDefault | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | fragment UserFragment on UserGQL { | ||||||
|  |   id | ||||||
|  |   firebaseUid | ||||||
|  |   username | ||||||
|  |   isAdmin | ||||||
|  |   profileImageUri | ||||||
|  |   fargoRating | ||||||
|  |   activeVideoId | ||||||
|  |   createdAt | ||||||
|  |   updatedAt | ||||||
|  |   videosPrivateByDefault | ||||||
|  | } | ||||||
|   | |||||||
| @@ -82,6 +82,57 @@ query GetVideoDetails($videoId: Int!) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | fragment UserSocialsFields on UserGQL { | ||||||
|  |   id | ||||||
|  |   username | ||||||
|  |   profileImageUri | ||||||
|  |   followers { | ||||||
|  |     id | ||||||
|  |     username | ||||||
|  |     profileImageUri | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetVideoSocialDetailsById($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     name | ||||||
|  |     owner { | ||||||
|  |       id | ||||||
|  |       firebaseUid | ||||||
|  |       username | ||||||
|  |       profileImageUri | ||||||
|  |     } | ||||||
|  |     tags { | ||||||
|  |       tagClasses { | ||||||
|  |         name | ||||||
|  |       } | ||||||
|  |       name | ||||||
|  |     } | ||||||
|  |     reactions { | ||||||
|  |       videoId | ||||||
|  |       user { | ||||||
|  |         ...UserSocialsFields | ||||||
|  |       } | ||||||
|  |       reaction | ||||||
|  |     } | ||||||
|  |     comments { | ||||||
|  |       id | ||||||
|  |       message | ||||||
|  |       user { | ||||||
|  |         ...UserSocialsFields | ||||||
|  |       } | ||||||
|  |       replies { | ||||||
|  |         id | ||||||
|  |         message | ||||||
|  |         user { | ||||||
|  |           ...UserSocialsFields | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| query GetVideos($videoIds: [Int!]!) { | query GetVideos($videoIds: [Int!]!) { | ||||||
|   getVideos(videoIds: $videoIds) { |   getVideos(videoIds: $videoIds) { | ||||||
|     ...VideoStreamMetadata |     ...VideoStreamMetadata | ||||||
| @@ -216,6 +267,23 @@ query GetHeaderInfoByVideoId($videoId: Int!) { | |||||||
|     startTime |     startTime | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | query GetBannerInfoByVideoId($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     name | ||||||
|  |     stream { | ||||||
|  |       id | ||||||
|  |       lastIntendedSegmentBound | ||||||
|  |     } | ||||||
|  |     owner { | ||||||
|  |       id | ||||||
|  |     } | ||||||
|  |     currentProcessing { | ||||||
|  |       id | ||||||
|  |       status | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | ||||||
|   findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { |   findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { | ||||||
|   | |||||||
| @@ -101,13 +101,8 @@ query GetUploadStreams( | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| query GetUploadStreamsWithDetails( |  | ||||||
|   $limit: Int! = 5 | fragment UploadStreamWithDetails on VideoGQL { | ||||||
|   $after: String = null |  | ||||||
|   $filters: VideoFilterInput = null |  | ||||||
| ) { |  | ||||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { |  | ||||||
|     videos { |  | ||||||
|   id |   id | ||||||
|   name |   name | ||||||
|   startTime |   startTime | ||||||
| @@ -118,6 +113,16 @@ query GetUploadStreamsWithDetails( | |||||||
|     uploadsCompleted |     uploadsCompleted | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | query GetUploadStreamsWithDetails( | ||||||
|  |   $limit: Int! = 5 | ||||||
|  |   $after: String = null | ||||||
|  |   $filters: VideoFilterInput = null | ||||||
|  | ) { | ||||||
|  |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |     videos { | ||||||
|  |       ...UploadStreamWithDetails | ||||||
|  |     } | ||||||
|     pageInfo { |     pageInfo { | ||||||
|       hasNextPage |       hasNextPage | ||||||
|       endCursor |       endCursor | ||||||
|   | |||||||
							
								
								
									
										446
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										446
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -5,10 +5,28 @@ type Query { | |||||||
|   getBucketSet(keyName: String!): BucketSetGQL |   getBucketSet(keyName: String!): BucketSetGQL | ||||||
|   getDeployedConfig: DeployedConfigGQL! |   getDeployedConfig: DeployedConfigGQL! | ||||||
|   waitFor(duration: Float!): Float! |   waitFor(duration: Float!): Float! | ||||||
|  |   getFeedVideos( | ||||||
|  |     limit: Int! = 5 | ||||||
|  |     after: String = null | ||||||
|  |     includePrivate: IncludePrivateEnum! = MINE | ||||||
|  |     includeCallersVideos: Boolean = true | ||||||
|  |     filters: VideoFilterInput = null | ||||||
|  |     feedInput: VideoFeedInputGQL = null | ||||||
|  |   ): VideoHistoryGQL! | ||||||
|   getVideoMakePercentageIntervals( |   getVideoMakePercentageIntervals( | ||||||
|     videoId: ID! |     videoId: ID! | ||||||
|     intervalDuration: Int! = 300 |     intervalDuration: Int! = 300 | ||||||
|   ): [MakePercentageIntervalGQL!]! |   ): [MakePercentageIntervalGQL!]! | ||||||
|  |   getLongestRunsLeaderboard( | ||||||
|  |     interval: TimeInterval = null | ||||||
|  |     when: DateTime = null | ||||||
|  |     limit: Int! = 100 | ||||||
|  |     requiredTags: [String!] = null | ||||||
|  |   ): RunLeaderboardGQL! | ||||||
|  |   getMakesLeaderboard( | ||||||
|  |     interval: TimeInterval = null | ||||||
|  |     when: DateTime = null | ||||||
|  |   ): CountLeaderboardGQL! | ||||||
|   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! |   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! | ||||||
|   getRuns( |   getRuns( | ||||||
|     filterInput: RunFilterInput! |     filterInput: RunFilterInput! | ||||||
| @@ -17,6 +35,12 @@ type Query { | |||||||
|     limit: Int! = 500 |     limit: Int! = 500 | ||||||
|     countRespectsLimit: Boolean! = false |     countRespectsLimit: Boolean! = false | ||||||
|   ): GetRunsResult! |   ): GetRunsResult! | ||||||
|  |   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||||
|  |   getTableState( | ||||||
|  |     b64Image: String! | ||||||
|  |     tableSize: Float = 100 | ||||||
|  |     useHomography: HomographyInputGQL = null | ||||||
|  |   ): TableStateGQL! | ||||||
|   getOrderedShots( |   getOrderedShots( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     ids: [Int!] = null |     ids: [Int!] = null | ||||||
| @@ -38,7 +62,6 @@ type Query { | |||||||
|     countRespectsLimit: Boolean! = false |     countRespectsLimit: Boolean! = false | ||||||
|   ): [ShotGQL!]! |   ): [ShotGQL!]! | ||||||
|   getShotsByIds(ids: [Int!]!): [ShotGQL!]! |   getShotsByIds(ids: [Int!]!): [ShotGQL!]! | ||||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! |  | ||||||
|   getUser(userId: Int!): UserGQL |   getUser(userId: Int!): UserGQL | ||||||
|   doesUsernameExist(candidateUsername: String!): Boolean! |   doesUsernameExist(candidateUsername: String!): Boolean! | ||||||
|   getLoggedInUser: UserGQL |   getLoggedInUser: UserGQL | ||||||
| @@ -60,17 +83,9 @@ type Query { | |||||||
|     after: String = null |     after: String = null | ||||||
|     filters: VideoFilterInput = null |     filters: VideoFilterInput = null | ||||||
|   ): VideoHistoryGQL! |   ): VideoHistoryGQL! | ||||||
|   getUserTags: [TagGQL!]! |   getUserTags(includeRetiredTags: Boolean = false): [TagGQL!]! | ||||||
|   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! |   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! | ||||||
|   getVideos(videoIds: [Int!]!): [VideoGQL!]! |   getVideos(videoIds: [Int!]!): [VideoGQL!]! | ||||||
|   getFeedVideos( |  | ||||||
|     limit: Int! = 5 |  | ||||||
|     after: String = null |  | ||||||
|     includePrivate: IncludePrivateEnum! = MINE |  | ||||||
|     includeCallersVideos: Boolean = true |  | ||||||
|     filters: VideoFilterInput = null |  | ||||||
|     feedInput: VideoFeedInputGQL = null |  | ||||||
|   ): VideoHistoryGQL! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type AggregateResultGQL { | type AggregateResultGQL { | ||||||
| @@ -173,6 +188,7 @@ input FilterInput @oneOf { | |||||||
|   shotDirection: [ShotDirectionEnum!] |   shotDirection: [ShotDirectionEnum!] | ||||||
|   videoId: [Int!] |   videoId: [Int!] | ||||||
|   userId: [Int!] |   userId: [Int!] | ||||||
|  |   runId: [Int!] | ||||||
|   username: [String!] |   username: [String!] | ||||||
|   fargoRating: FloatRangeFilter |   fargoRating: FloatRangeFilter | ||||||
|   make: [Boolean!] |   make: [Boolean!] | ||||||
| @@ -184,6 +200,7 @@ input FilterInput @oneOf { | |||||||
|   isLeftMiss: [Boolean!] |   isLeftMiss: [Boolean!] | ||||||
|   isRightMiss: [Boolean!] |   isRightMiss: [Boolean!] | ||||||
|   isDirect: [Boolean!] |   isDirect: [Boolean!] | ||||||
|  |   isBreakHeuristic: [Boolean!] | ||||||
|   tableSize: FloatRangeFilter |   tableSize: FloatRangeFilter | ||||||
|   bankAngle: FloatRangeFilter |   bankAngle: FloatRangeFilter | ||||||
|   bankDistance: FloatRangeFilter |   bankDistance: FloatRangeFilter | ||||||
| @@ -276,68 +293,54 @@ type DeployedConfigGQL { | |||||||
|   minimumAllowedAppVersion: String! |   minimumAllowedAppVersion: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| type MakePercentageIntervalGQL { | type VideoHistoryGQL { | ||||||
|   makePercentage: Float! |   videos: [VideoGQL!]! | ||||||
|   elapsedTime: Float! |   pageInfo: PageInfoGQL! | ||||||
| } | } | ||||||
|  |  | ||||||
| type RequestedMedalsGQL { | type VideoGQL { | ||||||
|   distanceOver66: MedalGQL |  | ||||||
|   distanceOver78: MedalGQL |  | ||||||
|   distanceOver90: MedalGQL |  | ||||||
|   runLength3: MedalGQL |  | ||||||
|   runLength5: MedalGQL |  | ||||||
|   runLength8: MedalGQL |  | ||||||
|   runLength10: MedalGQL |  | ||||||
|   runLength15: MedalGQL |  | ||||||
|   runLength20: MedalGQL |  | ||||||
|   runLength25: MedalGQL |  | ||||||
|   runLength30: MedalGQL |  | ||||||
|   runLength40: MedalGQL |  | ||||||
|   runLength50: MedalGQL |  | ||||||
|   totalMakes25: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes50: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes75: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   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 |  | ||||||
|   totalMakes500: MedalGQL |  | ||||||
|   totalMakes1000: MedalGQL |  | ||||||
|   totalMakes5000: MedalGQL |  | ||||||
|   totalMakes10000: MedalGQL |  | ||||||
|   dailyMakes50: MedalGQL |  | ||||||
|   dailyMakes100: MedalGQL |  | ||||||
|   dailyMakes150: MedalGQL |  | ||||||
|   dailyMakes200: MedalGQL |  | ||||||
|   dailyMakes250: MedalGQL |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type MedalGQL { |  | ||||||
|   count: Int! |  | ||||||
|   nickname: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input MedalScope @oneOf { |  | ||||||
|   videoId: Int |  | ||||||
|   interval: TimeInterval |  | ||||||
|     @deprecated(reason: "NO LONGER SUPPORTED, USE DATETIME_RANGE") |  | ||||||
|   datetimeRange: DatetimeRangeAggregationInput |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type GetRunsResult { |  | ||||||
|   runs: [RunGQL!]! |  | ||||||
|   count: Int |  | ||||||
|   runIds: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type RunGQL { |  | ||||||
|   id: Int! |   id: Int! | ||||||
|   runLength: Int! |   owner: UserGQL | ||||||
|   videoId: Int! |   name: String | ||||||
|   userId: Int! |   screenshotUri: String | ||||||
|  |   totalShotsMade: Int! | ||||||
|  |   totalShots: Int! | ||||||
|  |   makePercentage: Float! | ||||||
|  |   medianRun: Float | ||||||
|  |   averageTimeBetweenShots: Float | ||||||
|  |   averageDifficulty: Float | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|  |   startTime: DateTime | ||||||
|  |   endTime: DateTime | ||||||
|  |   elapsedTime: Float | ||||||
|  |   framesPerSecond: Float! | ||||||
|  |   tableSize: Float! | ||||||
|  |   private: Boolean! | ||||||
|  |   stream: UploadStreamGQL | ||||||
|  |   playlist: HLSPlaylistGQL | ||||||
|  |   tags: [VideoTag!]! | ||||||
|  |   currentHomography: HomographyInfoGQL | ||||||
|  |   homographyHistory: [HomographyInfoGQL!]! | ||||||
|  |   currentProcessing: VideoProcessingGQL | ||||||
|  |   reactions: [ReactionGQL!]! | ||||||
|  |   comments: [CommentGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type UserGQL { | ||||||
|  |   id: Int! | ||||||
|  |   firebaseUid: String | ||||||
|  |   username: String! | ||||||
|  |   isAdmin: Boolean | ||||||
|  |   fargoRating: Int | ||||||
|  |   activeVideoId: Int | ||||||
|  |   profileImageUri: String | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  |   videosPrivateByDefault: Boolean | ||||||
|  |   following: [UserGQL!] | ||||||
|  |   followers: [UserGQL!] | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotGQL { | type ShotGQL { | ||||||
| @@ -356,6 +359,8 @@ type ShotGQL { | |||||||
|   annotations: [ShotAnnotationGQL!]! |   annotations: [ShotAnnotationGQL!]! | ||||||
|   falsePositiveScore: Float |   falsePositiveScore: Float | ||||||
|   video: VideoGQL |   video: VideoGQL | ||||||
|  |   run: RunGQL | ||||||
|  |   runFeatures: RunFeaturesGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| type CueObjectFeaturesGQL { | type CueObjectFeaturesGQL { | ||||||
| @@ -407,21 +412,6 @@ type SerializedShotPathsGQL { | |||||||
|   b64EncodedBuffer: String |   b64EncodedBuffer: String | ||||||
| } | } | ||||||
|  |  | ||||||
| type UserGQL { |  | ||||||
|   id: Int! |  | ||||||
|   firebaseUid: String |  | ||||||
|   username: String! |  | ||||||
|   isAdmin: Boolean |  | ||||||
|   fargoRating: Int |  | ||||||
|   activeVideoId: Int |  | ||||||
|   profileImageUri: String |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
|   videosPrivateByDefault: Boolean |  | ||||||
|   following: [UserGQL!] |  | ||||||
|   followers: [UserGQL!] |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type ShotAnnotationGQL { | type ShotAnnotationGQL { | ||||||
|   shotId: Int! |   shotId: Int! | ||||||
|   type: ShotAnnotationTypeGQL! |   type: ShotAnnotationTypeGQL! | ||||||
| @@ -437,31 +427,19 @@ type ShotAnnotationTypeGQL { | |||||||
|   name: String! |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| type VideoGQL { | type RunGQL { | ||||||
|   id: Int! |   id: Int! | ||||||
|   owner: UserGQL |   runLength: Int! | ||||||
|   name: String |   videoId: Int! | ||||||
|   screenshotUri: String |   userId: Int! | ||||||
|   totalShotsMade: Int! |  | ||||||
|   totalShots: Int! |  | ||||||
|   makePercentage: Float! |  | ||||||
|   medianRun: Float |  | ||||||
|   averageTimeBetweenShots: Float |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|   startTime: DateTime |   video: VideoGQL! | ||||||
|   endTime: DateTime |   user: UserGQL! | ||||||
|   elapsedTime: Float | } | ||||||
|   framesPerSecond: Float! |  | ||||||
|   tableSize: Float! | type RunFeaturesGQL { | ||||||
|   private: Boolean! |   runId: Int! | ||||||
|   stream: UploadStreamGQL |   indexInRun: Int! | ||||||
|   playlist: HLSPlaylistGQL |  | ||||||
|   tags: [VideoTag!]! |  | ||||||
|   currentHomography: HomographyInfoGQL |  | ||||||
|   homographyHistory: [HomographyInfoGQL!]! |  | ||||||
|   currentProcessing: VideoProcessingGQL |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type UploadStreamGQL { | type UploadStreamGQL { | ||||||
| @@ -595,6 +573,124 @@ type VideoProcessingStatusGQL { | |||||||
|   updatedAt: DateTime |   updatedAt: DateTime | ||||||
| } | } | ||||||
|  |  | ||||||
|  | type ReactionGQL { | ||||||
|  |   videoId: Int! | ||||||
|  |   user: UserGQL! | ||||||
|  |   reaction: ReactionEnum! | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  | } | ||||||
|  |  | ||||||
|  | enum ReactionEnum { | ||||||
|  |   LIKE | ||||||
|  |   HEART | ||||||
|  |   BULLSEYE | ||||||
|  |   HUNDRED | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type CommentGQL { | ||||||
|  |   id: Int! | ||||||
|  |   user: UserGQL! | ||||||
|  |   message: String! | ||||||
|  |   replies: [CommentGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type PageInfoGQL { | ||||||
|  |   hasNextPage: Boolean! | ||||||
|  |   endCursor: String | ||||||
|  | } | ||||||
|  |  | ||||||
|  | enum IncludePrivateEnum { | ||||||
|  |   ALL | ||||||
|  |   MINE | ||||||
|  |   NONE | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input VideoFilterInput { | ||||||
|  |   isStreamCompleted: Boolean = null | ||||||
|  |   requireCursorCompletion: Boolean! = true | ||||||
|  |   createdAt: DateRangeFilter = null | ||||||
|  |   excludeVideosWithNoShots: Boolean = null | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input VideoFeedInputGQL @oneOf { | ||||||
|  |   followedByUserId: Int | ||||||
|  |   userId: Int | ||||||
|  |   allUsers: Boolean | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type MakePercentageIntervalGQL { | ||||||
|  |   makePercentage: Float! | ||||||
|  |   elapsedTime: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type RunLeaderboardGQL { | ||||||
|  |   entries: [RunGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type CountLeaderboardGQL { | ||||||
|  |   entries: [UserShotCountEntry!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type UserShotCountEntry { | ||||||
|  |   user: UserGQL! | ||||||
|  |   value: Int! | ||||||
|  |   total: Int! | ||||||
|  |   proportionMade: Float! | ||||||
|  |   videos: Int! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type RequestedMedalsGQL { | ||||||
|  |   distanceOver66: MedalGQL | ||||||
|  |   distanceOver78: MedalGQL | ||||||
|  |   distanceOver90: MedalGQL | ||||||
|  |   runLength3: MedalGQL | ||||||
|  |   runLength5: MedalGQL | ||||||
|  |   runLength8: MedalGQL | ||||||
|  |   runLength10: MedalGQL | ||||||
|  |   runLength15: MedalGQL | ||||||
|  |   runLength20: MedalGQL | ||||||
|  |   runLength25: MedalGQL | ||||||
|  |   runLength30: MedalGQL | ||||||
|  |   runLength40: MedalGQL | ||||||
|  |   runLength50: MedalGQL | ||||||
|  |   totalMakes25: MedalGQL @deprecated(reason: "no longer supported") | ||||||
|  |   totalMakes50: MedalGQL @deprecated(reason: "no longer supported") | ||||||
|  |   totalMakes75: MedalGQL @deprecated(reason: "no longer supported") | ||||||
|  |   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 | ||||||
|  |   totalMakes500: MedalGQL | ||||||
|  |   totalMakes1000: MedalGQL | ||||||
|  |   totalMakes5000: MedalGQL | ||||||
|  |   totalMakes10000: MedalGQL | ||||||
|  |   dailyMakes50: MedalGQL | ||||||
|  |   dailyMakes100: MedalGQL | ||||||
|  |   dailyMakes150: MedalGQL | ||||||
|  |   dailyMakes200: MedalGQL | ||||||
|  |   dailyMakes250: MedalGQL | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type MedalGQL { | ||||||
|  |   count: Int! | ||||||
|  |   nickname: String | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input MedalScope @oneOf { | ||||||
|  |   videoId: Int | ||||||
|  |   interval: TimeInterval | ||||||
|  |     @deprecated(reason: "NO LONGER SUPPORTED, USE DATETIME_RANGE") | ||||||
|  |   datetimeRange: DatetimeRangeAggregationInput | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type GetRunsResult { | ||||||
|  |   runs: [RunGQL!]! | ||||||
|  |   count: Int | ||||||
|  |   runIds: [Int!]! | ||||||
|  | } | ||||||
|  |  | ||||||
| input RunFilterInput { | input RunFilterInput { | ||||||
|   videoId: [Int!] |   videoId: [Int!] | ||||||
|   userId: [Int!] |   userId: [Int!] | ||||||
| @@ -627,6 +723,39 @@ input DatetimeOrdering { | |||||||
|   startingAt: DateTime = null |   startingAt: DateTime = null | ||||||
| } | } | ||||||
|  |  | ||||||
|  | type TableStateGQL { | ||||||
|  |   identifierToPosition: [[Float!]!]! | ||||||
|  |   homography: HomographyInfoGQL | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input HomographyInputGQL { | ||||||
|  |   crop: BoundingBoxInputGQL! | ||||||
|  |   pockets: [BoundingBoxInputGQL!]! | ||||||
|  |   sourcePoints: PocketPointsInputGQL! | ||||||
|  |   destPoints: PocketPointsInputGQL! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input BoundingBoxInputGQL { | ||||||
|  |   left: Float! | ||||||
|  |   top: Float! | ||||||
|  |   width: Float! | ||||||
|  |   height: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input PocketPointsInputGQL { | ||||||
|  |   topLeft: IntPoint2DInput! | ||||||
|  |   topSide: IntPoint2DInput! | ||||||
|  |   topRight: IntPoint2DInput! | ||||||
|  |   bottomLeft: IntPoint2DInput! | ||||||
|  |   bottomSide: IntPoint2DInput! | ||||||
|  |   bottomRight: IntPoint2DInput! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input IntPoint2DInput { | ||||||
|  |   x: Int! | ||||||
|  |   y: Int! | ||||||
|  | } | ||||||
|  |  | ||||||
| type GetShotsResult { | type GetShotsResult { | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|   count: Int |   count: Int | ||||||
| @@ -676,27 +805,16 @@ type UserPlayTimeGQL { | |||||||
|   totalSeconds: Float! |   totalSeconds: Float! | ||||||
| } | } | ||||||
|  |  | ||||||
| input VideoFilterInput { |  | ||||||
|   isStreamCompleted: Boolean = null |  | ||||||
|   requireCursorCompletion: Boolean! = true |  | ||||||
|   createdAt: DateRangeFilter = null |  | ||||||
|   excludeVideosWithNoShots: Boolean = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoHistoryGQL { |  | ||||||
|   videos: [VideoGQL!]! |  | ||||||
|   pageInfo: PageInfoGQL! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type PageInfoGQL { |  | ||||||
|   hasNextPage: Boolean! |  | ||||||
|   endCursor: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type TagGQL { | type TagGQL { | ||||||
|   name: String! |  | ||||||
|   id: Int! |   id: Int! | ||||||
|   group: String |   name: String! | ||||||
|  |   tagClasses: [TagClassGQL!] | ||||||
|  |   retired: Boolean! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type TagClassGQL { | ||||||
|  |   id: Int! | ||||||
|  |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| """ | """ | ||||||
| @@ -707,25 +825,17 @@ scalar JSON | |||||||
|     url: "https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf" |     url: "https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf" | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
| enum IncludePrivateEnum { |  | ||||||
|   ALL |  | ||||||
|   MINE |  | ||||||
|   NONE |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input VideoFeedInputGQL @oneOf { |  | ||||||
|   followedByUserId: Int |  | ||||||
|   userId: Int |  | ||||||
|   allUsers: Boolean |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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( |   reactToVideo(videoId: Int!, reaction: ReactionEnum): Boolean! | ||||||
|     shotId: Int! |   commentOnVideo( | ||||||
|     fieldsToEdit: EditableShotFieldInputGQL! |     videoId: Int! | ||||||
|   ): EditShotReturn! |     message: String! | ||||||
|  |     parentCommentId: Int | ||||||
|  |   ): Boolean! | ||||||
|  |   editComment(videoId: Int!, commentId: Int!, newMessage: String!): Boolean! | ||||||
|  |   deleteComment(videoId: Int!, commentId: Int!): Boolean! | ||||||
|   addAnnotationToShot( |   addAnnotationToShot( | ||||||
|     shotId: Int! |     shotId: Int! | ||||||
|     annotationName: String! |     annotationName: String! | ||||||
| @@ -735,6 +845,10 @@ type Mutation { | |||||||
|     shotId: Int! |     shotId: Int! | ||||||
|     annotations: [UpdateAnnotationInputGQL!]! |     annotations: [UpdateAnnotationInputGQL!]! | ||||||
|   ): UpdateShotAnnotationReturn! |   ): UpdateShotAnnotationReturn! | ||||||
|  |   editShot( | ||||||
|  |     shotId: Int! | ||||||
|  |     fieldsToEdit: EditableShotFieldInputGQL! | ||||||
|  |   ): EditShotReturn! | ||||||
|   getProfileImageUploadLink( |   getProfileImageUploadLink( | ||||||
|     fileExt: String = ".png" |     fileExt: String = ".png" | ||||||
|   ): GetProfileUploadLinkReturn! |   ): GetProfileUploadLinkReturn! | ||||||
| @@ -742,6 +856,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! | ||||||
|  |   retireTags(tagIds: [Int!]!): Boolean! | ||||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL |   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||||
|   createUploadStream( |   createUploadStream( | ||||||
|     videoMetadata: VideoMetadataInput! |     videoMetadata: VideoMetadataInput! | ||||||
| @@ -755,6 +870,7 @@ type Mutation { | |||||||
|   ): Boolean! |   ): Boolean! | ||||||
|   editUploadStream(videoId: Int!, videoMetadata: VideoMetadataInput!): Boolean! |   editUploadStream(videoId: Int!, videoMetadata: VideoMetadataInput!): Boolean! | ||||||
|   deleteVideo(videoId: Int!): Boolean! |   deleteVideo(videoId: Int!): Boolean! | ||||||
|  |   deleteTags(videoId: Int!, tagsToDelete: [VideoTagInput!]!): Boolean! | ||||||
| } | } | ||||||
|  |  | ||||||
| input CreateBucketSetInput { | input CreateBucketSetInput { | ||||||
| @@ -763,27 +879,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! | ||||||
| } | } | ||||||
| @@ -804,6 +899,11 @@ union DoesNotOwnShotErrOtherErrorNeedsNote = | |||||||
|     DoesNotOwnShotErr |     DoesNotOwnShotErr | ||||||
|   | OtherErrorNeedsNote |   | OtherErrorNeedsNote | ||||||
|  |  | ||||||
|  | type DoesNotOwnShotErr { | ||||||
|  |   shotId: Int! | ||||||
|  |   msg: String | ||||||
|  | } | ||||||
|  |  | ||||||
| type OtherErrorNeedsNote { | type OtherErrorNeedsNote { | ||||||
|   msg: String |   msg: String | ||||||
| } | } | ||||||
| @@ -818,6 +918,22 @@ input UpdateAnnotationInputGQL { | |||||||
|   notes: String = null |   notes: String = null | ||||||
| } | } | ||||||
|  |  | ||||||
|  | type EditShotReturn { | ||||||
|  |   shot: ShotGQL | ||||||
|  |   error: DoesNotOwnShotErr | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input EditableShotFieldInputGQL { | ||||||
|  |   intendedPocketType: PocketEnum | ||||||
|  |   shotDirection: ShotDirectionEnum | ||||||
|  |   spinType: SpinTypeEnum | ||||||
|  |   targetPocketAngleDirection: ShotDirectionEnum | ||||||
|  |   make: Boolean | ||||||
|  |   backcut: Boolean | ||||||
|  |   excludeFromStats: Boolean | ||||||
|  |   notes: String | ||||||
|  | } | ||||||
|  |  | ||||||
| type GetProfileUploadLinkReturn { | type GetProfileUploadLinkReturn { | ||||||
|   value: UploadLinkGetProfileUploadLinkErrors! |   value: UploadLinkGetProfileUploadLinkErrors! | ||||||
| } | } | ||||||
| @@ -859,6 +975,12 @@ input VideoMetadataInput { | |||||||
|   startTime: DateTime = null |   startTime: DateTime = null | ||||||
|   endTime: DateTime = null |   endTime: DateTime = null | ||||||
|   gameType: String = null |   gameType: String = null | ||||||
|  |     @deprecated(reason: "`game_type` is deprecated. Use `tags` instead.") | ||||||
|  |  | ||||||
|  |   """ | ||||||
|  |   A list of tags associated with the video. Replace `game_type` | ||||||
|  |   """ | ||||||
|  |   tags: [VideoTagInput!] = null | ||||||
|   tableSize: Float = null |   tableSize: Float = null | ||||||
|   lastIntendedSegmentBound: Int = null |   lastIntendedSegmentBound: Int = null | ||||||
|   streamSegmentType: StreamSegmentTypeEnum = null |   streamSegmentType: StreamSegmentTypeEnum = null | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -10,10 +10,10 @@ | |||||||
|     "@jridgewell/gen-mapping" "^0.3.0" |     "@jridgewell/gen-mapping" "^0.3.0" | ||||||
|     "@jridgewell/trace-mapping" "^0.3.9" |     "@jridgewell/trace-mapping" "^0.3.9" | ||||||
|  |  | ||||||
| "@apollo/client@^3.9.2": | "@apollo/client@^3.11.10": | ||||||
|   version "3.9.2" |   version "3.12.3" | ||||||
|   resolved "https://registry.yarnpkg.com/@apollo/client/-/client-3.9.2.tgz#96edf2c212f828bad1ef3d84234fa473c5a27ff8" |   resolved "https://registry.yarnpkg.com/@apollo/client/-/client-3.12.3.tgz#0d252749baad8328e06883fe118dc7e73e3bbb1f" | ||||||
|   integrity sha512-Zw9WvXjqhpbgkvAvnj52vstOWwM0iedKWtn1hSq1cODQyoe1CF2uFwMYFI7l56BrAY9CzLi6MQA0AhxpgJgvxw== |   integrity sha512-KZ5zymRdb8bMbGUb1wP2U04ff7qIGgaC1BCdCVC+IPFiXkxEhHBc5fDEQOwAUT+vUo9KbBh3g7QK/JCOswn59w== | ||||||
|   dependencies: |   dependencies: | ||||||
|     "@graphql-typed-document-node/core" "^3.1.1" |     "@graphql-typed-document-node/core" "^3.1.1" | ||||||
|     "@wry/caches" "^1.0.0" |     "@wry/caches" "^1.0.0" | ||||||
| @@ -23,7 +23,7 @@ | |||||||
|     hoist-non-react-statics "^3.3.2" |     hoist-non-react-statics "^3.3.2" | ||||||
|     optimism "^0.18.0" |     optimism "^0.18.0" | ||||||
|     prop-types "^15.7.2" |     prop-types "^15.7.2" | ||||||
|     rehackt "0.0.3" |     rehackt "^0.1.0" | ||||||
|     response-iterator "^0.2.6" |     response-iterator "^0.2.6" | ||||||
|     symbol-observable "^4.0.0" |     symbol-observable "^4.0.0" | ||||||
|     ts-invariant "^0.10.3" |     ts-invariant "^0.10.3" | ||||||
| @@ -2633,10 +2633,10 @@ regenerator-runtime@^0.14.0: | |||||||
|   resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz#356ade10263f685dda125100cd862c1db895327f" |   resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz#356ade10263f685dda125100cd862c1db895327f" | ||||||
|   integrity sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw== |   integrity sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw== | ||||||
|  |  | ||||||
| rehackt@0.0.3: | rehackt@^0.1.0: | ||||||
|   version "0.0.3" |   version "0.1.0" | ||||||
|   resolved "https://registry.yarnpkg.com/rehackt/-/rehackt-0.0.3.tgz#1ea454620d4641db8342e2db44595cf0e7ac6aa0" |   resolved "https://registry.yarnpkg.com/rehackt/-/rehackt-0.1.0.tgz#a7c5e289c87345f70da8728a7eb878e5d03c696b" | ||||||
|   integrity sha512-aBRHudKhOWwsTvCbSoinzq+Lej/7R8e8UoPvLZo5HirZIIBLGAgdG7SL9QpdcBoQ7+3QYPi3lRLknAzXBlhZ7g== |   integrity sha512-7kRDOuLHB87D/JESKxQoRwv4DzbIdwkAGQ7p6QKGdVlY1IZheUnVhlk/4UZlNUVxdAXpyxikE3URsG067ybVzw== | ||||||
|  |  | ||||||
| relay-runtime@12.0.0: | relay-runtime@12.0.0: | ||||||
|   version "12.0.0" |   version "12.0.0" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user