Compare commits
	
		
			113 Commits
		
	
	
		
			af461fff00
			...
			kat/delete
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 99f8968a36 | |||
| 76a98aa0c3 | |||
| f5177a877c | |||
| 6685849cc2 | |||
| 567cbc549c | |||
| 2b43493a4f | |||
| 358eee2e16 | |||
| a1d3d776aa | |||
| 82af3a3ce9 | |||
| 7b51c317ca | |||
| 04f1bb4d74 | |||
| fbd7c2020b | |||
| c0636a8863 | |||
| 7302d6b8b6 | |||
| 492178455c | |||
| 55a2edb042 | |||
| 31cf492889 | |||
| de7dc675a1 | |||
| f8f00d9c24 | |||
| dc207bce55 | |||
| 2e5b8d2563 | |||
| 46bcd08ae1 | |||
| bd383b1d55 | |||
| 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 | |||
| 33886b4e9e | |||
| 9d0ba908dc | |||
| 7b4880a990 | |||
| 8ed177b0f3 | |||
| 976cc66ccb | 
| @@ -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", | ||||||
|   | |||||||
| @@ -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 { | ||||||
|   | |||||||
							
								
								
									
										2310
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										2310
									
								
								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) | ||||||
|  | } | ||||||
| @@ -5,5 +5,13 @@ query getDeployedConfig { | |||||||
|     environment |     environment | ||||||
|     firebase |     firebase | ||||||
|     minimumAllowedAppVersion |     minimumAllowedAppVersion | ||||||
|  |     bannerMessages { | ||||||
|  |       color | ||||||
|  |       dismissible | ||||||
|  |       id | ||||||
|  |       kind | ||||||
|  |       message | ||||||
|  |       priority | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -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( | ||||||
| @@ -62,12 +98,16 @@ query GetVideoFeed( | |||||||
|   $after: String = null |   $after: String = null | ||||||
|   $filters: VideoFilterInput = null |   $filters: VideoFilterInput = null | ||||||
|   $includeCallersVideos: Boolean = null |   $includeCallersVideos: Boolean = null | ||||||
|  |   $includePrivate: IncludePrivateEnum = MINE | ||||||
|  |   $feedInput: VideoFeedInputGQL = null | ||||||
| ) { | ) { | ||||||
|   getFeedVideos( |   getFeedVideos( | ||||||
|     limit: $limit |     limit: $limit | ||||||
|     after: $after |     after: $after | ||||||
|     filters: $filters |     filters: $filters | ||||||
|     includeCallersVideos: $includeCallersVideos |     includeCallersVideos: $includeCallersVideos | ||||||
|  |     includePrivate: $includePrivate | ||||||
|  |     feedInput: $feedInput | ||||||
|   ) { |   ) { | ||||||
|     videos { |     videos { | ||||||
|       ...VideoCardFields |       ...VideoCardFields | ||||||
|   | |||||||
							
								
								
									
										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 | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								src/operations/payments.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								src/operations/payments.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | mutation EnsureStripeCustomerExists { | ||||||
|  |   ensureStripeCustomerExists { | ||||||
|  |     id | ||||||
|  |     firebaseUid | ||||||
|  |     username | ||||||
|  |     stripeCustomerId | ||||||
|  |     profileImageUri | ||||||
|  |     isAdmin | ||||||
|  |     fargoRating | ||||||
|  |     videosPrivateByDefault | ||||||
|  |     createdAt | ||||||
|  |     updatedAt | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										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,4 +185,23 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|     } |     } | ||||||
|     notes |     notes | ||||||
|   } |   } | ||||||
|  |   video { | ||||||
|  |     id | ||||||
|  |     stream { | ||||||
|  |       id | ||||||
|  |       streamSegmentType | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { | ||||||
|  |   editShot(shotId: $shotId, fieldsToEdit: $fieldsToEdit) { | ||||||
|  |     error { | ||||||
|  |       shotId | ||||||
|  |       msg | ||||||
|  |     } | ||||||
|  |     shot { | ||||||
|  |       ...ShotWithAllFeatures | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										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 | ||||||
| @@ -117,6 +112,16 @@ query GetUploadStreamsWithDetails( | |||||||
|     uploadCompletionCursor |     uploadCompletionCursor | ||||||
|     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 | ||||||
|   | |||||||
							
								
								
									
										486
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										486
									
								
								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 | ||||||
| @@ -47,12 +70,18 @@ type Query { | |||||||
|     limit: Int = null |     limit: Int = null | ||||||
|     after: String = null |     after: String = null | ||||||
|   ): [String!]! |   ): [String!]! | ||||||
|  |   getUsersMatching( | ||||||
|  |     matchString: String = null | ||||||
|  |     limit: Int = null | ||||||
|  |     after: String = null | ||||||
|  |   ): [UserGQL!]! | ||||||
|   getUserRelationshipsMatching( |   getUserRelationshipsMatching( | ||||||
|     userId: Int! |     userId: Int! | ||||||
|     matchString: String = null |     matchString: String = null | ||||||
|     limit: Int = 100 |     limit: Int = 100 | ||||||
|     after: String = null |     after: String = null | ||||||
|   ): UserRelationshipsResult! |   ): UserRelationshipsResult! | ||||||
|  |   getAvailableSubscriptionOptions: StripeSubscriptionOptionsGQL! | ||||||
|   getPlayTime(userId: Int!, filters: VideoFilterInput = null): UserPlayTimeGQL! |   getPlayTime(userId: Int!, filters: VideoFilterInput = null): UserPlayTimeGQL! | ||||||
|   getUserVideos( |   getUserVideos( | ||||||
|     userId: Int = null |     userId: Int = null | ||||||
| @@ -60,15 +89,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 |  | ||||||
|     includeCallersVideos: Boolean = true |  | ||||||
|     filters: VideoFilterInput = null |  | ||||||
|   ): VideoHistoryGQL! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type AggregateResultGQL { | type AggregateResultGQL { | ||||||
| @@ -171,6 +194,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!] | ||||||
| @@ -182,6 +206,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 | ||||||
| @@ -272,70 +297,73 @@ type DeployedConfigGQL { | |||||||
|   devMode: Boolean! |   devMode: Boolean! | ||||||
|   environment: String! |   environment: String! | ||||||
|   minimumAllowedAppVersion: String! |   minimumAllowedAppVersion: String! | ||||||
|  |   bannerMessages: [BannerGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type MakePercentageIntervalGQL { | type BannerGQL { | ||||||
|   makePercentage: Float! |  | ||||||
|   elapsedTime: Float! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type RunGQL { |  | ||||||
|   id: Int! |   id: Int! | ||||||
|   runLength: Int! |   message: String! | ||||||
|   videoId: Int! |   color: String! | ||||||
|   userId: Int! |   kind: BannerKindEnum! | ||||||
|  |   dismissible: Boolean! | ||||||
|  |   priority: Int! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | enum BannerKindEnum { | ||||||
|  |   INFO | ||||||
|  |   WARNING | ||||||
|  |   ERROR | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type VideoHistoryGQL { | ||||||
|  |   videos: [VideoGQL!]! | ||||||
|  |   pageInfo: PageInfoGQL! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type VideoGQL { | ||||||
|  |   id: Int! | ||||||
|  |   owner: UserGQL | ||||||
|  |   name: String | ||||||
|  |   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 | ||||||
|  |   stripeCustomerId: String | ||||||
|  |   profileImageUri: String | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  |   videosPrivateByDefault: Boolean | ||||||
|  |   following: [UserGQL!] | ||||||
|  |   followers: [UserGQL!] | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotGQL { | type ShotGQL { | ||||||
| @@ -354,6 +382,8 @@ type ShotGQL { | |||||||
|   annotations: [ShotAnnotationGQL!]! |   annotations: [ShotAnnotationGQL!]! | ||||||
|   falsePositiveScore: Float |   falsePositiveScore: Float | ||||||
|   video: VideoGQL |   video: VideoGQL | ||||||
|  |   run: RunGQL | ||||||
|  |   runFeatures: RunFeaturesGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| type CueObjectFeaturesGQL { | type CueObjectFeaturesGQL { | ||||||
| @@ -405,21 +435,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! | ||||||
| @@ -435,31 +450,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 { | ||||||
| @@ -566,6 +569,9 @@ type VideoProcessingGQL { | |||||||
|   errors: [VideoProcessingErrorGQL!]! |   errors: [VideoProcessingErrorGQL!]! | ||||||
|   status: ProcessingStatusEnum! |   status: ProcessingStatusEnum! | ||||||
|   statuses: [VideoProcessingStatusGQL!]! |   statuses: [VideoProcessingStatusGQL!]! | ||||||
|  |   framesProcessed: Int | ||||||
|  |   currentSegment: Int | ||||||
|  |   progressPercentage: Float | ||||||
| } | } | ||||||
|  |  | ||||||
| type VideoProcessingErrorGQL { | type VideoProcessingErrorGQL { | ||||||
| @@ -593,6 +599,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!] | ||||||
| @@ -625,6 +749,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 | ||||||
| @@ -670,31 +827,42 @@ type UserRelationship { | |||||||
|   toUserIsFollowedBy: Boolean! |   toUserIsFollowedBy: Boolean! | ||||||
| } | } | ||||||
|  |  | ||||||
|  | type StripeSubscriptionOptionsGQL { | ||||||
|  |   products: [StripeProductGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type StripeProductGQL { | ||||||
|  |   id: String! | ||||||
|  |   name: String! | ||||||
|  |   description: String | ||||||
|  |   active: Boolean! | ||||||
|  |   prices: [StripePriceGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type StripePriceGQL { | ||||||
|  |   id: String! | ||||||
|  |   currency: String! | ||||||
|  |   unitAmount: Int | ||||||
|  |   recurringInterval: String | ||||||
|  |   recurringIntervalCount: Int | ||||||
|  |   type: String! | ||||||
|  |   active: Boolean! | ||||||
|  | } | ||||||
|  |  | ||||||
| type UserPlayTimeGQL { | 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! | ||||||
| } | } | ||||||
|  |  | ||||||
| """ | """ | ||||||
| @@ -708,10 +876,14 @@ 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( |   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! | ||||||
| @@ -721,6 +893,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! | ||||||
| @@ -728,6 +904,9 @@ 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! | ||||||
|  |   ensureStripeCustomerExists: UserGQL! | ||||||
|  |   deleteUser: Boolean! | ||||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL |   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||||
|   createUploadStream( |   createUploadStream( | ||||||
|     videoMetadata: VideoMetadataInput! |     videoMetadata: VideoMetadataInput! | ||||||
| @@ -741,6 +920,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 { | ||||||
| @@ -749,27 +929,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 +949,11 @@ union DoesNotOwnShotErrOtherErrorNeedsNote = | |||||||
|     DoesNotOwnShotErr |     DoesNotOwnShotErr | ||||||
|   | OtherErrorNeedsNote |   | OtherErrorNeedsNote | ||||||
|  |  | ||||||
|  | type DoesNotOwnShotErr { | ||||||
|  |   shotId: Int! | ||||||
|  |   msg: String | ||||||
|  | } | ||||||
|  |  | ||||||
| type OtherErrorNeedsNote { | type OtherErrorNeedsNote { | ||||||
|   msg: String |   msg: String | ||||||
| } | } | ||||||
| @@ -804,6 +968,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! | ||||||
| } | } | ||||||
| @@ -845,6 +1025,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