Compare commits
	
		
			86 Commits
		
	
	
		
			mk/extend-
			...
			b18fedae8e
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 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 | |||
| af461fff00 | |||
| 7a39b4ca60 | |||
| 9befbe3833 | |||
| 68a4c064f3 | |||
| 54fd741670 | |||
| 2f9e630de4 | |||
| 5efd8ef8e5 | |||
| 6ad3d449d8 | |||
| 8fe20d1c41 | |||
| e151f39582 | |||
| f136ddb9ca | |||
| 5d05614e07 | |||
| c4c3ccde00 | |||
| e137ce8ad1 | |||
| bd5bebb747 | |||
| 034facebf3 | |||
| ac1fceb648 | 
| @@ -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 { | ||||||
|   | |||||||
							
								
								
									
										1544
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										1544
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -27,6 +27,8 @@ fragment VideoCardFields on VideoGQL { | |||||||
|   totalShotsMade |   totalShotsMade | ||||||
|   totalShots |   totalShots | ||||||
|   makePercentage |   makePercentage | ||||||
|  |   averageTimeBetweenShots | ||||||
|  |   averageDifficulty | ||||||
|   createdAt |   createdAt | ||||||
|   updatedAt |   updatedAt | ||||||
|   startTime |   startTime | ||||||
| @@ -36,6 +38,7 @@ fragment VideoCardFields on VideoGQL { | |||||||
|   screenshotUri |   screenshotUri | ||||||
|   stream { |   stream { | ||||||
|     id |     id | ||||||
|  |     lastIntendedSegmentBound | ||||||
|     isCompleted |     isCompleted | ||||||
|   } |   } | ||||||
|   tableSize |   tableSize | ||||||
| @@ -55,6 +58,15 @@ fragment VideoCardFields on VideoGQL { | |||||||
|       status |       status | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |   reactions { | ||||||
|  |     videoId | ||||||
|  |     user { | ||||||
|  |       id | ||||||
|  |       username | ||||||
|  |       profileImageUri | ||||||
|  |     } | ||||||
|  |     reaction | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query GetVideoFeed( | query GetVideoFeed( | ||||||
| @@ -62,12 +74,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 | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -1,84 +1,75 @@ | |||||||
|  | fragment MedalFields on MedalGQL { | ||||||
|  |   count | ||||||
|  |   nickname | ||||||
|  | } | ||||||
|  |  | ||||||
| query getMedals($scope: MedalScope!, $userId: Int) { | query getMedals($scope: MedalScope!, $userId: Int) { | ||||||
|   getMedals(scope: $scope, userId: $userId) { |   getMedals(scope: $scope, userId: $userId) { | ||||||
|     distanceOver66 { |  | ||||||
|       count |  | ||||||
|       nickname |  | ||||||
|     } |  | ||||||
|     distanceOver78 { |     distanceOver78 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     distanceOver90 { |     distanceOver90 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength3 { |     runLength3 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength5 { |     runLength5 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength8 { |     runLength8 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength10 { |     runLength10 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength15 { |     runLength15 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength20 { |     runLength20 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength25 { |     runLength25 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength30 { |     runLength30 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength40 { |     runLength40 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     runLength50 { |     runLength50 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |  | ||||||
|     totalMakes25 { |  | ||||||
|       count |  | ||||||
|       nickname |  | ||||||
|     } |  | ||||||
|     totalMakes50 { |  | ||||||
|       count |  | ||||||
|       nickname |  | ||||||
|     } |  | ||||||
|     totalMakes75 { |  | ||||||
|       count |  | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     totalMakes100 { |     totalMakes100 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     totalMakes200 { |     totalMakes500 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     totalMakes300 { |     totalMakes1000 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |  | ||||||
|     } |     } | ||||||
|     totalMakes400 { |     totalMakes5000 { | ||||||
|       count |       ...MedalFields | ||||||
|       nickname |     } | ||||||
|  |     totalMakes10000 { | ||||||
|  |       ...MedalFields | ||||||
|  |     } | ||||||
|  |     dailyMakes50 { | ||||||
|  |       ...MedalFields | ||||||
|  |     } | ||||||
|  |     dailyMakes100 { | ||||||
|  |       ...MedalFields | ||||||
|  |     } | ||||||
|  |     dailyMakes150 { | ||||||
|  |       ...MedalFields | ||||||
|  |     } | ||||||
|  |     dailyMakes200 { | ||||||
|  |       ...MedalFields | ||||||
|  |     } | ||||||
|  |     dailyMakes250 { | ||||||
|  |       ...MedalFields | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										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) | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								src/operations/runs.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								src/operations/runs.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | query GetRunsForHighlights( | ||||||
|  |   $filterInput: RunFilterInput! | ||||||
|  |   $runIds: [Int!] = null | ||||||
|  |   $runsOrdering: GetRunsOrdering | ||||||
|  | ) { | ||||||
|  |   getRuns( | ||||||
|  |     filterInput: $filterInput | ||||||
|  |     runIds: $runIds | ||||||
|  |     runsOrdering: $runsOrdering | ||||||
|  |   ) { | ||||||
|  |     count | ||||||
|  |     runs { | ||||||
|  |       id | ||||||
|  |       runLength | ||||||
|  |       userId | ||||||
|  |       videoId | ||||||
|  |       shots { | ||||||
|  |         videoId | ||||||
|  |         id | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     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 | ||||||
|   } |   } | ||||||
| @@ -178,3 +186,15 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|     notes |     notes | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | 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 | ||||||
|  | } | ||||||
|   | |||||||
| @@ -36,6 +36,7 @@ query GetVideoUpdatePageDetails($videoId: Int!) { | |||||||
|     makePercentage |     makePercentage | ||||||
|     elapsedTime |     elapsedTime | ||||||
|     tableSize |     tableSize | ||||||
|  |     private | ||||||
|     tags { |     tags { | ||||||
|       tagClasses { |       tagClasses { | ||||||
|         name |         name | ||||||
| @@ -65,6 +66,7 @@ query GetVideoDetails($videoId: Int!) { | |||||||
|     createdAt |     createdAt | ||||||
|     updatedAt |     updatedAt | ||||||
|     tableSize |     tableSize | ||||||
|  |     private | ||||||
|     owner { |     owner { | ||||||
|       id |       id | ||||||
|       firebaseUid |       firebaseUid | ||||||
| @@ -214,6 +216,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) { | ||||||
| @@ -222,6 +241,7 @@ mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | |||||||
| } | } | ||||||
|  |  | ||||||
| fragment HomographyInfo on HomographyInfoGQL { | fragment HomographyInfo on HomographyInfoGQL { | ||||||
|  |   id | ||||||
|   frameIndex |   frameIndex | ||||||
|   crop { |   crop { | ||||||
|     left |     left | ||||||
|   | |||||||
| @@ -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 | ||||||
|   | |||||||
							
								
								
									
										122
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										122
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -60,15 +60,27 @@ 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( |   getFeedVideos( | ||||||
|     limit: Int! = 5 |     limit: Int! = 5 | ||||||
|     after: String = null |     after: String = null | ||||||
|  |     includePrivate: IncludePrivateEnum! = MINE | ||||||
|     includeCallersVideos: Boolean = true |     includeCallersVideos: Boolean = true | ||||||
|     filters: VideoFilterInput = null |     filters: VideoFilterInput = null | ||||||
|  |     feedInput: VideoFeedInputGQL = null | ||||||
|   ): VideoHistoryGQL! |   ): VideoHistoryGQL! | ||||||
|  |   getLongestRunsLeaderboard( | ||||||
|  |     interval: TimeInterval = null | ||||||
|  |     when: DateTime = null | ||||||
|  |     limit: Int! = 100 | ||||||
|  |     requiredTags: [String!] = null | ||||||
|  |   ): RunLeaderboardGQL! | ||||||
|  |   getMakesLeaderboard( | ||||||
|  |     interval: TimeInterval = null | ||||||
|  |     when: DateTime = null | ||||||
|  |   ): CountLeaderboardGQL! | ||||||
| } | } | ||||||
|  |  | ||||||
| type AggregateResultGQL { | type AggregateResultGQL { | ||||||
| @@ -171,6 +183,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 +195,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 | ||||||
| @@ -320,6 +334,8 @@ type MedalGQL { | |||||||
| input MedalScope @oneOf { | input MedalScope @oneOf { | ||||||
|   videoId: Int |   videoId: Int | ||||||
|   interval: TimeInterval |   interval: TimeInterval | ||||||
|  |     @deprecated(reason: "NO LONGER SUPPORTED, USE DATETIME_RANGE") | ||||||
|  |   datetimeRange: DatetimeRangeAggregationInput | ||||||
| } | } | ||||||
|  |  | ||||||
| type GetRunsResult { | type GetRunsResult { | ||||||
| @@ -334,6 +350,8 @@ type RunGQL { | |||||||
|   videoId: Int! |   videoId: Int! | ||||||
|   userId: Int! |   userId: Int! | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|  |   video: VideoGQL! | ||||||
|  |   user: UserGQL! | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotGQL { | type ShotGQL { | ||||||
| @@ -352,6 +370,8 @@ type ShotGQL { | |||||||
|   annotations: [ShotAnnotationGQL!]! |   annotations: [ShotAnnotationGQL!]! | ||||||
|   falsePositiveScore: Float |   falsePositiveScore: Float | ||||||
|   video: VideoGQL |   video: VideoGQL | ||||||
|  |   run: RunGQL | ||||||
|  |   runFeatures: RunFeaturesGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| type CueObjectFeaturesGQL { | type CueObjectFeaturesGQL { | ||||||
| @@ -443,6 +463,7 @@ type VideoGQL { | |||||||
|   makePercentage: Float! |   makePercentage: Float! | ||||||
|   medianRun: Float |   medianRun: Float | ||||||
|   averageTimeBetweenShots: Float |   averageTimeBetweenShots: Float | ||||||
|  |   averageDifficulty: Float | ||||||
|   createdAt: DateTime |   createdAt: DateTime | ||||||
|   updatedAt: DateTime |   updatedAt: DateTime | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
| @@ -458,6 +479,7 @@ type VideoGQL { | |||||||
|   currentHomography: HomographyInfoGQL |   currentHomography: HomographyInfoGQL | ||||||
|   homographyHistory: [HomographyInfoGQL!]! |   homographyHistory: [HomographyInfoGQL!]! | ||||||
|   currentProcessing: VideoProcessingGQL |   currentProcessing: VideoProcessingGQL | ||||||
|  |   reactions: [ReactionGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type UploadStreamGQL { | type UploadStreamGQL { | ||||||
| @@ -591,6 +613,26 @@ 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 RunFeaturesGQL { | ||||||
|  |   runId: Int! | ||||||
|  |   indexInRun: Int! | ||||||
|  | } | ||||||
|  |  | ||||||
| input RunFilterInput { | input RunFilterInput { | ||||||
|   videoId: [Int!] |   videoId: [Int!] | ||||||
|   userId: [Int!] |   userId: [Int!] | ||||||
| @@ -636,6 +678,7 @@ input GetShotsOrdering { | |||||||
| input ShotsOrderingComponent @oneOf { | input ShotsOrderingComponent @oneOf { | ||||||
|   videoCreation: DatetimeOrdering |   videoCreation: DatetimeOrdering | ||||||
|   marginOfError: FloatOrdering |   marginOfError: FloatOrdering | ||||||
|  |   difficulty: FloatOrdering | ||||||
|   videoId: IntOrdering |   videoId: IntOrdering | ||||||
|   startFrame: IntOrdering |   startFrame: IntOrdering | ||||||
|   runLength: IntOrdering |   runLength: IntOrdering | ||||||
| @@ -689,9 +732,15 @@ type PageInfoGQL { | |||||||
| } | } | ||||||
|  |  | ||||||
| type TagGQL { | type TagGQL { | ||||||
|   name: String! |  | ||||||
|   id: Int! |   id: Int! | ||||||
|   group: String |   name: String! | ||||||
|  |   tagClasses: [TagClassGQL!] | ||||||
|  |   retired: Boolean! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type TagClassGQL { | ||||||
|  |   id: Int! | ||||||
|  |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| """ | """ | ||||||
| @@ -702,9 +751,41 @@ 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 RunLeaderboardGQL { | ||||||
|  |   entries: [RunGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type CountLeaderboardGQL { | ||||||
|  |   entries: [UserShotCountEntry!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type UserShotCountEntry { | ||||||
|  |   user: UserGQL! | ||||||
|  |   value: Int! | ||||||
|  |   total: Int! | ||||||
|  |   proportionMade: Float! | ||||||
|  |   videos: Int! | ||||||
|  | } | ||||||
|  |  | ||||||
| type Mutation { | type Mutation { | ||||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! |   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||||
|   setLoggerLevel(path: String!, level: String!): Boolean! |   setLoggerLevel(path: String!, level: String!): Boolean! | ||||||
|  |   editShot( | ||||||
|  |     shotId: Int! | ||||||
|  |     fieldsToEdit: EditableShotFieldInputGQL! | ||||||
|  |   ): EditShotReturn! | ||||||
|   addAnnotationToShot( |   addAnnotationToShot( | ||||||
|     shotId: Int! |     shotId: Int! | ||||||
|     annotationName: String! |     annotationName: String! | ||||||
| @@ -721,6 +802,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! | ||||||
| @@ -734,6 +816,8 @@ 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! | ||||||
|  |   reactToVideo(videoId: Int!, reaction: ReactionEnum): Boolean! | ||||||
| } | } | ||||||
|  |  | ||||||
| input CreateBucketSetInput { | input CreateBucketSetInput { | ||||||
| @@ -742,6 +826,27 @@ 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! | ||||||
| } | } | ||||||
| @@ -762,11 +867,6 @@ union DoesNotOwnShotErrOtherErrorNeedsNote = | |||||||
|     DoesNotOwnShotErr |     DoesNotOwnShotErr | ||||||
|   | OtherErrorNeedsNote |   | OtherErrorNeedsNote | ||||||
|  |  | ||||||
| type DoesNotOwnShotErr { |  | ||||||
|   shotId: Int! |  | ||||||
|   msg: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type OtherErrorNeedsNote { | type OtherErrorNeedsNote { | ||||||
|   msg: String |   msg: String | ||||||
| } | } | ||||||
| @@ -822,6 +922,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