Compare commits
	
		
			1 Commits
		
	
	
		
			master
			...
			loewy/incl
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b34bce6e5f | 
| @@ -12,7 +12,7 @@ | ||||
|   "author": "Ivan Malison <IvanMalison@gmail.com>", | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
|     "@apollo/client": "^3.11.10", | ||||
|     "@apollo/client": "^3.9.2", | ||||
|     "@graphql-codegen/cli": "^5.0.0", | ||||
|     "@graphql-codegen/typescript": "^4.0.1", | ||||
|     "@graphql-codegen/typescript-operations": "^4.0.1", | ||||
|   | ||||
| @@ -1,16 +1,9 @@ | ||||
| # see: https://www.apollographql.com/docs/react/local-state/managing-state-with-field-policies/ | ||||
| directive @client on FIELD | ||||
|  | ||||
| type SegmentInfo { | ||||
|   index: Int! | ||||
|   time: Float! | ||||
| } | ||||
|  | ||||
| extend type ShotGQL { | ||||
|   startTime: Float! | ||||
|   endTime: Float! | ||||
|   startSegment: SegmentInfo! | ||||
|   endSegment: SegmentInfo! | ||||
| } | ||||
|  | ||||
| extend type UploadStreamGQL { | ||||
|   | ||||
							
								
								
									
										3572
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										3572
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,19 +0,0 @@ | ||||
| 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,14 +5,5 @@ query getDeployedConfig { | ||||
|     environment | ||||
|     firebase | ||||
|     minimumAllowedAppVersion | ||||
|     subscriptionGatingEnabled | ||||
|     bannerMessages { | ||||
|       color | ||||
|       dismissible | ||||
|       id | ||||
|       kind | ||||
|       message | ||||
|       priority | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,15 +0,0 @@ | ||||
| mutation blockContent($videoId: Int!) { | ||||
|   blockContent(videoId: $videoId) | ||||
| } | ||||
|  | ||||
| mutation blockUser($userId: Int!) { | ||||
|   blockUser(userId: $userId) | ||||
| } | ||||
|  | ||||
| mutation reportContent( | ||||
|   $videoId: Int! | ||||
|   $reason: ReportReasonEnum! | ||||
|   $customReason: String = null | ||||
| ) { | ||||
|   reportContent(videoId: $videoId, reason: $reason, customReason: $customReason) | ||||
| } | ||||
| @@ -6,7 +6,32 @@ query GetFeed( | ||||
| ) { | ||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|     videos { | ||||
|       ...VideoCardFields | ||||
|       id | ||||
|       owner { | ||||
|         username | ||||
|       } | ||||
|       name | ||||
|       screenshotUri | ||||
|       totalShotsMade | ||||
|       totalShots | ||||
|       makePercentage | ||||
|       createdAt | ||||
|       updatedAt | ||||
|       startTime | ||||
|       endTime | ||||
|       elapsedTime | ||||
|       screenshotUri | ||||
|       stream { | ||||
|         id | ||||
|         isCompleted | ||||
|       } | ||||
|       tableSize | ||||
|       tags { | ||||
|         tagClasses { | ||||
|           name | ||||
|         } | ||||
|         name | ||||
|       } | ||||
|     } | ||||
|     pageInfo { | ||||
|       hasNextPage | ||||
| @@ -15,17 +40,6 @@ query GetFeed( | ||||
|   } | ||||
| } | ||||
|  | ||||
| fragment UserSocialsFields on UserGQL { | ||||
|   id | ||||
|   username | ||||
|   profileImageUri | ||||
|   followers { | ||||
|     id | ||||
|     username | ||||
|     profileImageUri | ||||
|   } | ||||
| } | ||||
|  | ||||
| fragment VideoCardFields on VideoGQL { | ||||
|   id | ||||
|   owner { | ||||
| @@ -38,20 +52,15 @@ fragment VideoCardFields on VideoGQL { | ||||
|   totalShotsMade | ||||
|   totalShots | ||||
|   makePercentage | ||||
|   averageTimeBetweenShots | ||||
|   averageDifficulty | ||||
|   createdAt | ||||
|   updatedAt | ||||
|   startTime | ||||
|   endTime | ||||
|   private | ||||
|   elapsedTime | ||||
|   screenshotUri | ||||
|   stream { | ||||
|     id | ||||
|     lastIntendedSegmentBound | ||||
|     isCompleted | ||||
|     streamSegmentType | ||||
|   } | ||||
|   tableSize | ||||
|   tags { | ||||
| @@ -70,45 +79,14 @@ fragment VideoCardFields on VideoGQL { | ||||
|       status | ||||
|     } | ||||
|   } | ||||
|   reactions { | ||||
|     videoId | ||||
|     user { | ||||
|       ...UserSocialsFields | ||||
|     } | ||||
|     reaction | ||||
|   } | ||||
|   comments { | ||||
|     id | ||||
|     message | ||||
|     user { | ||||
|       ...UserSocialsFields | ||||
|     } | ||||
|     replies { | ||||
|       id | ||||
|       message | ||||
|       user { | ||||
|         ...UserSocialsFields | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetVideoFeed( | ||||
|   $limit: Int! = 5 | ||||
|   $after: String = null | ||||
|   $filters: VideoFilterInput = null | ||||
|   $includeCallersVideos: Boolean = null | ||||
|   $includePrivate: IncludePrivateEnum = MINE | ||||
|   $feedInput: VideoFeedInputGQL = null | ||||
| ) { | ||||
|   getFeedVideos( | ||||
|     limit: $limit | ||||
|     after: $after | ||||
|     filters: $filters | ||||
|     includeCallersVideos: $includeCallersVideos | ||||
|     includePrivate: $includePrivate | ||||
|     feedInput: $feedInput | ||||
| ) { | ||||
|   getFeedVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|     videos { | ||||
|       ...VideoCardFields | ||||
|     } | ||||
|   | ||||
| @@ -1,32 +0,0 @@ | ||||
| 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,75 +0,0 @@ | ||||
| fragment MedalFields on MedalGQL { | ||||
|   count | ||||
|   nickname | ||||
| } | ||||
|  | ||||
| query getMedals($scope: MedalScope!, $userId: Int) { | ||||
|   getMedals(scope: $scope, userId: $userId) { | ||||
|     distanceOver78 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     distanceOver90 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength3 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength5 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength8 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength10 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength15 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength20 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength25 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength30 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength40 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     runLength50 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes100 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes500 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes1000 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes5000 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     totalMakes10000 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes50 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes100 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes150 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes200 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|     dailyMakes250 { | ||||
|       ...MedalFields | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -1,65 +0,0 @@ | ||||
| mutation EnsureStripeCustomerExists { | ||||
|   ensureStripeCustomerExists { | ||||
|     id | ||||
|     firebaseUid | ||||
|     username | ||||
|     stripeCustomerId | ||||
|     profileImageUri | ||||
|     isAdmin | ||||
|     fargoRating | ||||
|     videosPrivateByDefault | ||||
|     createdAt | ||||
|     updatedAt | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation CreateSubscription($priceId: String!) { | ||||
|   createSubscription(priceId: $priceId) { | ||||
|     checkoutUrl | ||||
|     sessionId | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetAvailableSubscriptionOptions { | ||||
|   getAvailableSubscriptionOptions { | ||||
|     products { | ||||
|       id | ||||
|       name | ||||
|       description | ||||
|       active | ||||
|       prices { | ||||
|         id | ||||
|         currency | ||||
|         unitAmount | ||||
|         recurringInterval | ||||
|         recurringIntervalCount | ||||
|         type | ||||
|         active | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetSubscriptionStatus { | ||||
|   getUserSubscriptionStatus { | ||||
|     hasActiveSubscription | ||||
|     subscriptionStatus | ||||
|     currentPeriodStart | ||||
|     currentPeriodEnd | ||||
|     validUntil | ||||
|     stripePriceId | ||||
|     stripeSubscriptionId | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation CancelSubscription { | ||||
|   cancelSubscription { | ||||
|     hasActiveSubscription | ||||
|     subscriptionStatus | ||||
|     currentPeriodStart | ||||
|     currentPeriodEnd | ||||
|     validUntil | ||||
|     stripePriceId | ||||
|     stripeSubscriptionId | ||||
|   } | ||||
| } | ||||
| @@ -1,3 +0,0 @@ | ||||
| mutation ReactToVideo($videoId: Int!, $reaction: ReactionEnum) { | ||||
|   reactToVideo(videoId: $videoId, reaction: $reaction) | ||||
| } | ||||
| @@ -1,67 +0,0 @@ | ||||
| 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 | ||||
|   } | ||||
| } | ||||
| @@ -66,15 +66,12 @@ query GetShotsWithJustIds( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsOrdering: GetShotsOrdering | ||||
|   $limit: Int | ||||
|   $countRespectsLimit: Boolean | ||||
| ) { | ||||
|   getOrderedShots( | ||||
|     filterInput: $filterInput | ||||
|     shotsOrdering: $shotsOrdering | ||||
|     limit: $limit | ||||
|     countRespectsLimit: $countRespectsLimit | ||||
|   ) { | ||||
|     count | ||||
|     shots { | ||||
|       id | ||||
|       videoId | ||||
| @@ -139,14 +136,6 @@ fragment ShotWithAllFeatures on ShotGQL { | ||||
|   endFrame | ||||
|   startTime @client | ||||
|   endTime @client | ||||
|   startSegment @client { | ||||
|     index | ||||
|     time | ||||
|   } | ||||
|   endSegment @client { | ||||
|     index | ||||
|     time | ||||
|   } | ||||
|   user { | ||||
|     id | ||||
|   } | ||||
| @@ -167,7 +156,6 @@ fragment ShotWithAllFeatures on ShotGQL { | ||||
|     targetPocketAngleDirection | ||||
|     marginOfErrorInDegrees | ||||
|     intendedPocketType | ||||
|     difficulty | ||||
|   } | ||||
|   pocketingIntentionInfo { | ||||
|     ballId | ||||
| @@ -185,23 +173,4 @@ fragment ShotWithAllFeatures on ShotGQL { | ||||
|     } | ||||
|     notes | ||||
|   } | ||||
|   video { | ||||
|     id | ||||
|     stream { | ||||
|       id | ||||
|       streamSegmentType | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { | ||||
|   editShot(shotId: $shotId, fieldsToEdit: $fieldsToEdit) { | ||||
|     error { | ||||
|       shotId | ||||
|       msg | ||||
|     } | ||||
|     shot { | ||||
|       ...ShotWithAllFeatures | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,7 +0,0 @@ | ||||
| mutation RetireTags($tagIds: [Int!]!) { | ||||
|   retireTags(tagIds: $tagIds) | ||||
| } | ||||
|  | ||||
| mutation DeleteTags($videoId: Int!, $tagsToDelete: [VideoTagInput!]!) { | ||||
|   deleteTags(videoId: $videoId, tagsToDelete: $tagsToDelete) | ||||
| } | ||||
| @@ -21,24 +21,31 @@ mutation getProfileImageUploadLink($fileExt: String = ".png") { | ||||
|  | ||||
| mutation editProfileImageUri($profileImageUri: String!) { | ||||
|   editProfileImageUri(profileImageUri: $profileImageUri) { | ||||
|     ...UserFragment | ||||
|     id | ||||
|     firebaseUid | ||||
|     username | ||||
|     profileImageUri | ||||
|     createdAt | ||||
|     updatedAt | ||||
|   } | ||||
| } | ||||
|  | ||||
| query getLoggedInUser { | ||||
|   getLoggedInUser { | ||||
|     ...UserFragment | ||||
|     id | ||||
|     firebaseUid | ||||
|     username | ||||
|     isAdmin | ||||
|     profileImageUri | ||||
|     fargoRating | ||||
|     activeVideoId | ||||
|     createdAt | ||||
|     updatedAt | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetUser($userId: Int!) { | ||||
|   getUser(userId: $userId) { | ||||
|     ...UserFragment | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetUserPlayTime($userId: Int!, $filters: VideoFilterInput) { | ||||
|   getPlayTime(userId: $userId, filters: $filters) { | ||||
| query GetUserPlayTime($userId: Int!) { | ||||
|   getPlayTime(userId: $userId) { | ||||
|     totalSeconds | ||||
|   } | ||||
| } | ||||
| @@ -66,7 +73,6 @@ query getUserRelationshipsMatching( | ||||
|     relationships { | ||||
|       toUser { | ||||
|         username | ||||
|         profileImageUri | ||||
|         id | ||||
|       } | ||||
|       toUserFollows | ||||
| @@ -79,10 +85,6 @@ query GetUserTags { | ||||
|   getUserTags { | ||||
|     id | ||||
|     name | ||||
|     tagClasses { | ||||
|       id | ||||
|       name | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| @@ -122,12 +124,10 @@ query getUserFollowingFollowers { | ||||
|     following { | ||||
|       id | ||||
|       username | ||||
|       profileImageUri | ||||
|     } | ||||
|     followers { | ||||
|       id | ||||
|       username | ||||
|       profileImageUri | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -135,45 +135,3 @@ query getUserFollowingFollowers { | ||||
| query doesUsernameExist($candidateUsername: String!) { | ||||
|   doesUsernameExist(candidateUsername: $candidateUsername) | ||||
| } | ||||
|  | ||||
| mutation editUser( | ||||
|   $username: String | ||||
|   $fargoRating: Int | ||||
|   $videosPrivateByDefault: Boolean | ||||
|   $agreesToMarketing: Boolean | ||||
| ) { | ||||
|   editUser( | ||||
|     input: { | ||||
|       username: $username | ||||
|       fargoRating: $fargoRating | ||||
|       videosPrivateByDefault: $videosPrivateByDefault | ||||
|       agreesToMarketing: $agreesToMarketing | ||||
|     } | ||||
|   ) { | ||||
|     id | ||||
|     firebaseUid | ||||
|     username | ||||
|     fargoRating | ||||
|     updatedAt | ||||
|     videosPrivateByDefault | ||||
|     agreesToMarketing | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation deleteUser { | ||||
|   deleteUser | ||||
| } | ||||
|  | ||||
| fragment UserFragment on UserGQL { | ||||
|   id | ||||
|   firebaseUid | ||||
|   username | ||||
|   isAdmin | ||||
|   profileImageUri | ||||
|   fargoRating | ||||
|   activeVideoId | ||||
|   createdAt | ||||
|   updatedAt | ||||
|   videosPrivateByDefault | ||||
|   agreesToMarketing | ||||
| } | ||||
|   | ||||
| @@ -18,7 +18,6 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | ||||
|       initPlaylistUploadStatus | ||||
|     } | ||||
|     currentProcessing { | ||||
|       id | ||||
|       errors { | ||||
|         message | ||||
|         startSegmentIndex | ||||
| @@ -36,7 +35,6 @@ query GetVideoUpdatePageDetails($videoId: Int!) { | ||||
|     makePercentage | ||||
|     elapsedTime | ||||
|     tableSize | ||||
|     private | ||||
|     tags { | ||||
|       tagClasses { | ||||
|         name | ||||
| @@ -66,7 +64,6 @@ query GetVideoDetails($videoId: Int!) { | ||||
|     createdAt | ||||
|     updatedAt | ||||
|     tableSize | ||||
|     private | ||||
|     owner { | ||||
|       id | ||||
|       firebaseUid | ||||
| @@ -82,57 +79,6 @@ 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!]!) { | ||||
|   getVideos(videoIds: $videoIds) { | ||||
|     ...VideoStreamMetadata | ||||
| @@ -267,23 +213,6 @@ query GetHeaderInfoByVideoId($videoId: Int!) { | ||||
|     startTime | ||||
|   } | ||||
| } | ||||
| query GetBannerInfoByVideoId($videoId: Int!) { | ||||
|   getVideo(videoId: $videoId) { | ||||
|     id | ||||
|     name | ||||
|     stream { | ||||
|       id | ||||
|       lastIntendedSegmentBound | ||||
|     } | ||||
|     owner { | ||||
|       id | ||||
|     } | ||||
|     currentProcessing { | ||||
|       id | ||||
|       status | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { | ||||
|   findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { | ||||
|   | ||||
| @@ -101,8 +101,13 @@ query GetUploadStreams( | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| fragment UploadStreamWithDetails on VideoGQL { | ||||
| query GetUploadStreamsWithDetails( | ||||
|   $limit: Int! = 5 | ||||
|   $after: String = null | ||||
|   $filters: VideoFilterInput = null | ||||
| ) { | ||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|     videos { | ||||
|       id | ||||
|       name | ||||
|       startTime | ||||
| @@ -113,16 +118,6 @@ fragment UploadStreamWithDetails on VideoGQL { | ||||
|         uploadsCompleted | ||||
|       } | ||||
|     } | ||||
|  | ||||
| query GetUploadStreamsWithDetails( | ||||
|   $limit: Int! = 5 | ||||
|   $after: String = null | ||||
|   $filters: VideoFilterInput = null | ||||
| ) { | ||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||
|     videos { | ||||
|       ...UploadStreamWithDetails | ||||
|     } | ||||
|     pageInfo { | ||||
|       hasNextPage | ||||
|       endCursor | ||||
|   | ||||
							
								
								
									
										567
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										567
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -5,42 +5,11 @@ type Query { | ||||
|   getBucketSet(keyName: String!): BucketSetGQL | ||||
|   getDeployedConfig: DeployedConfigGQL! | ||||
|   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( | ||||
|     videoId: ID! | ||||
|     intervalDuration: Int! = 300 | ||||
|   ): [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! | ||||
|   getRuns( | ||||
|     filterInput: RunFilterInput! | ||||
|     runIds: [Int!] = null | ||||
|     runsOrdering: GetRunsOrdering = null | ||||
|     limit: Int! = 500 | ||||
|     countRespectsLimit: Boolean! = false | ||||
|   ): GetRunsResult! | ||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||
|   getTableState( | ||||
|     b64Image: String! | ||||
|     tableSize: Float = 100 | ||||
|     useHomography: HomographyInputGQL = null | ||||
|   ): TableStateGQL! | ||||
|   getOrderedShots( | ||||
|     filterInput: FilterInput! | ||||
|     ids: [Int!] = null | ||||
| @@ -62,6 +31,7 @@ type Query { | ||||
|     countRespectsLimit: Boolean! = false | ||||
|   ): [ShotGQL!]! | ||||
|   getShotsByIds(ids: [Int!]!): [ShotGQL!]! | ||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||
|   getUser(userId: Int!): UserGQL | ||||
|   doesUsernameExist(candidateUsername: String!): Boolean! | ||||
|   getLoggedInUser: UserGQL | ||||
| @@ -70,29 +40,27 @@ type Query { | ||||
|     limit: Int = null | ||||
|     after: String = null | ||||
|   ): [String!]! | ||||
|   getUsersMatching( | ||||
|     matchString: String = null | ||||
|     limit: Int = null | ||||
|     after: String = null | ||||
|   ): [UserGQL!]! | ||||
|   getUserRelationshipsMatching( | ||||
|     userId: Int! | ||||
|     matchString: String = null | ||||
|     limit: Int = 100 | ||||
|     after: String = null | ||||
|   ): UserRelationshipsResult! | ||||
|   getAvailableSubscriptionOptions: StripeSubscriptionOptionsGQL! | ||||
|   getUserSubscriptionStatus: UserSubscriptionStatusGQL! | ||||
|   getPlayTime(userId: Int!, filters: VideoFilterInput = null): UserPlayTimeGQL! | ||||
|   getPlayTime(userId: Int!): UserPlayTimeGQL! | ||||
|   getUserVideos( | ||||
|     userId: Int = null | ||||
|     limit: Int! = 5 | ||||
|     after: String = null | ||||
|     filters: VideoFilterInput = null | ||||
|   ): VideoHistoryGQL! | ||||
|   getUserTags(includeRetiredTags: Boolean = false): [TagGQL!]! | ||||
|   getUserTags: [TagGQL!]! | ||||
|   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! | ||||
|   getVideos(videoIds: [Int!]!): [VideoGQL!]! | ||||
|   getFeedVideos( | ||||
|     limit: Int! = 5 | ||||
|     after: String = null | ||||
|     filters: VideoFilterInput = null | ||||
|   ): VideoHistoryGQL! | ||||
| } | ||||
|  | ||||
| type AggregateResultGQL { | ||||
| @@ -195,7 +163,6 @@ input FilterInput @oneOf { | ||||
|   shotDirection: [ShotDirectionEnum!] | ||||
|   videoId: [Int!] | ||||
|   userId: [Int!] | ||||
|   runId: [Int!] | ||||
|   username: [String!] | ||||
|   fargoRating: FloatRangeFilter | ||||
|   make: [Boolean!] | ||||
| @@ -207,7 +174,6 @@ input FilterInput @oneOf { | ||||
|   isLeftMiss: [Boolean!] | ||||
|   isRightMiss: [Boolean!] | ||||
|   isDirect: [Boolean!] | ||||
|   isBreakHeuristic: [Boolean!] | ||||
|   tableSize: FloatRangeFilter | ||||
|   bankAngle: FloatRangeFilter | ||||
|   bankDistance: FloatRangeFilter | ||||
| @@ -298,75 +264,63 @@ type DeployedConfigGQL { | ||||
|   devMode: Boolean! | ||||
|   environment: String! | ||||
|   minimumAllowedAppVersion: String! | ||||
|   subscriptionGatingEnabled: Boolean! | ||||
|   bannerMessages: [BannerGQL!]! | ||||
| } | ||||
|  | ||||
| type BannerGQL { | ||||
|   id: Int! | ||||
|   message: String! | ||||
|   color: String! | ||||
|   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! | ||||
| type MakePercentageIntervalGQL { | ||||
|   makePercentage: Float! | ||||
|   medianRun: Float | ||||
|   averageTimeBetweenShots: Float | ||||
|   averageDifficulty: Float | ||||
|   createdAt: DateTime | ||||
|   updatedAt: DateTime | ||||
|   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!]! | ||||
|   elapsedTime: Float! | ||||
| } | ||||
|  | ||||
| type UserGQL { | ||||
|   id: Int! | ||||
|   firebaseUid: String | ||||
|   username: String! | ||||
|   isAdmin: Boolean | ||||
|   fargoRating: Int | ||||
|   activeVideoId: Int | ||||
|   stripeCustomerId: String | ||||
|   profileImageUri: String | ||||
|   createdAt: DateTime | ||||
|   updatedAt: DateTime | ||||
|   videosPrivateByDefault: Boolean | ||||
|   agreesToMarketing: Boolean | ||||
|   following: [UserGQL!] | ||||
|   followers: [UserGQL!] | ||||
| 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 | ||||
|   totalMakes50: MedalGQL | ||||
|   totalMakes75: MedalGQL | ||||
|   totalMakes100: MedalGQL | ||||
|   totalMakes200: MedalGQL | ||||
|   totalMakes300: MedalGQL | ||||
|   totalMakes400: MedalGQL | ||||
|   totalMakes500: MedalGQL | ||||
|   totalMakes750: MedalGQL | ||||
|   totalMakes1000: MedalGQL | ||||
|   dayStreak2: MedalGQL | ||||
|   dayStreak3: MedalGQL | ||||
|   dayStreak4: MedalGQL | ||||
|   dayStreak5: MedalGQL | ||||
|   dayStreak6: MedalGQL | ||||
|   dayStreak7: MedalGQL | ||||
|   dayStreak14: MedalGQL | ||||
|   dayStreak21: MedalGQL | ||||
|   dayStreak30: MedalGQL | ||||
|   dayStreak60: MedalGQL | ||||
|   dayStreak90: MedalGQL | ||||
| } | ||||
|  | ||||
| type MedalGQL { | ||||
|   count: Int! | ||||
| } | ||||
|  | ||||
| input MedalScope @oneOf { | ||||
|   videoId: Int | ||||
|   interval: TimeInterval | ||||
| } | ||||
|  | ||||
| type GetShotsResult { | ||||
|   shots: [ShotGQL!]! | ||||
|   count: Int | ||||
|   ids: [Int!]! | ||||
| } | ||||
|  | ||||
| type ShotGQL { | ||||
| @@ -385,8 +339,6 @@ type ShotGQL { | ||||
|   annotations: [ShotAnnotationGQL!]! | ||||
|   falsePositiveScore: Float | ||||
|   video: VideoGQL | ||||
|   run: RunGQL | ||||
|   runFeatures: RunFeaturesGQL | ||||
| } | ||||
|  | ||||
| type CueObjectFeaturesGQL { | ||||
| @@ -438,6 +390,21 @@ type SerializedShotPathsGQL { | ||||
|   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 { | ||||
|   shotId: Int! | ||||
|   type: ShotAnnotationTypeGQL! | ||||
| @@ -453,19 +420,31 @@ type ShotAnnotationTypeGQL { | ||||
|   name: String! | ||||
| } | ||||
|  | ||||
| type RunGQL { | ||||
| type VideoGQL { | ||||
|   id: Int! | ||||
|   runLength: Int! | ||||
|   videoId: Int! | ||||
|   userId: Int! | ||||
|   owner: UserGQL | ||||
|   name: String | ||||
|   screenshotUri: String | ||||
|   totalShotsMade: Int! | ||||
|   totalShots: Int! | ||||
|   makePercentage: Float! | ||||
|   medianRun: Float | ||||
|   averageTimeBetweenShots: Float | ||||
|   createdAt: DateTime | ||||
|   updatedAt: DateTime | ||||
|   shots: [ShotGQL!]! | ||||
|   video: VideoGQL! | ||||
|   user: UserGQL! | ||||
| } | ||||
|  | ||||
| type RunFeaturesGQL { | ||||
|   runId: Int! | ||||
|   indexInRun: Int! | ||||
|   startTime: DateTime | ||||
|   endTime: DateTime | ||||
|   elapsedTime: Float | ||||
|   framesPerSecond: Float! | ||||
|   tableSize: Float! | ||||
|   private: Boolean! | ||||
|   stream: UploadStreamGQL | ||||
|   playlist: HLSPlaylistGQL | ||||
|   tags: [VideoTag!]! | ||||
|   currentHomography: HomographyInfoGQL | ||||
|   homographyHistory: [HomographyInfoGQL!]! | ||||
|   currentProcessing: VideoProcessingGQL | ||||
| } | ||||
|  | ||||
| type UploadStreamGQL { | ||||
| @@ -482,7 +461,6 @@ type UploadStreamGQL { | ||||
|   createdAt: DateTime! | ||||
|   updatedAt: DateTime! | ||||
|   segments: [UploadSegmentGQL!]! | ||||
|   clientUploadStatus: ClientUploadStatusEnum | ||||
|   resolution: VideoResolutionGQL! | ||||
|   streamSegmentType: StreamSegmentTypeEnum! | ||||
| } | ||||
| @@ -507,11 +485,6 @@ type UploadSegmentGQL { | ||||
|   linksRequested: Int! | ||||
| } | ||||
|  | ||||
| enum ClientUploadStatusEnum { | ||||
|   UPLOAD_ENABLED | ||||
|   UPLOAD_DISABLED | ||||
| } | ||||
|  | ||||
| type VideoResolutionGQL { | ||||
|   width: Int | ||||
|   height: Int | ||||
| @@ -572,9 +545,6 @@ type VideoProcessingGQL { | ||||
|   errors: [VideoProcessingErrorGQL!]! | ||||
|   status: ProcessingStatusEnum! | ||||
|   statuses: [VideoProcessingStatusGQL!]! | ||||
|   framesProcessed: Int | ||||
|   currentSegment: Int | ||||
|   progressPercentage: Float | ||||
| } | ||||
|  | ||||
| type VideoProcessingErrorGQL { | ||||
| @@ -602,213 +572,33 @@ type VideoProcessingStatusGQL { | ||||
|   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 { | ||||
|   videoId: [Int!] | ||||
|   userId: [Int!] | ||||
|   username: [String!] | ||||
|   andFilters: [RunFilterInput!] | ||||
|   orFilters: [RunFilterInput!] | ||||
|   notFilter: RunFilterInput | ||||
|   tableSize: FloatRangeFilter | ||||
|   createdAt: DateRangeFilter | ||||
|   runLength: FloatRangeFilter | ||||
| } | ||||
|  | ||||
| input GetRunsOrdering { | ||||
|   orderings: [RunsOrderingComponent!]! | ||||
| } | ||||
|  | ||||
| input RunsOrderingComponent @oneOf { | ||||
|   runLength: IntOrdering | ||||
|   videoId: IntOrdering | ||||
|   videoCreation: DatetimeOrdering | ||||
| } | ||||
|  | ||||
| input IntOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: Int = null | ||||
| } | ||||
|  | ||||
| input DatetimeOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: DateTime = null | ||||
| } | ||||
|  | ||||
| type 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 { | ||||
|   shots: [ShotGQL!]! | ||||
|   count: Int | ||||
|   ids: [Int!]! | ||||
| } | ||||
|  | ||||
| input GetShotsOrdering { | ||||
|   orderings: [ShotsOrderingComponent!]! | ||||
| } | ||||
|  | ||||
| input ShotsOrderingComponent @oneOf { | ||||
|   videoCreation: DatetimeOrdering | ||||
|   marginOfError: FloatOrdering | ||||
|   difficulty: FloatOrdering | ||||
|   videoId: IntOrdering | ||||
|   startFrame: IntOrdering | ||||
|   runLength: IntOrdering | ||||
|   videoCreation: DatetimeShotOrdering | ||||
|   marginOfError: FloatShotOrdering | ||||
|   videoId: IntShotOrdering | ||||
|   startFrame: IntShotOrdering | ||||
|   runLength: IntShotOrdering | ||||
| } | ||||
|  | ||||
| input FloatOrdering { | ||||
| input DatetimeShotOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: DateTime = null | ||||
| } | ||||
|  | ||||
| input FloatShotOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: Float = null | ||||
| } | ||||
|  | ||||
| input IntShotOrdering { | ||||
|   descending: Boolean! = true | ||||
|   startingAt: Int = null | ||||
| } | ||||
|  | ||||
| input GetShotsPagination { | ||||
|   createdAfter: CreatedAfter! | ||||
|   startFrameAfter: Int! | ||||
| @@ -830,63 +620,29 @@ type UserRelationship { | ||||
|   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 UserSubscriptionStatusGQL { | ||||
|   hasActiveSubscription: Boolean! | ||||
|   subscriptionStatus: StripeSubscriptionStatusEnum | ||||
|   currentPeriodStart: DateTime | ||||
|   currentPeriodEnd: DateTime | ||||
|   validUntil: DateTime | ||||
|   stripePriceId: String | ||||
|   stripeSubscriptionId: String | ||||
| } | ||||
|  | ||||
| enum StripeSubscriptionStatusEnum { | ||||
|   INCOMPLETE | ||||
|   INCOMPLETE_EXPIRED | ||||
|   TRIALING | ||||
|   ACTIVE | ||||
|   PAST_DUE | ||||
|   CANCELED | ||||
|   UNPAID | ||||
|   PAUSED | ||||
| } | ||||
|  | ||||
| type UserPlayTimeGQL { | ||||
|   totalSeconds: Float! | ||||
| } | ||||
|  | ||||
| type TagGQL { | ||||
|   id: Int! | ||||
|   name: String! | ||||
|   tagClasses: [TagClassGQL!] | ||||
|   retired: Boolean! | ||||
| type VideoHistoryGQL { | ||||
|   videos: [VideoGQL!]! | ||||
|   pageInfo: PageInfoGQL! | ||||
| } | ||||
|  | ||||
| type TagClassGQL { | ||||
|   id: Int! | ||||
| type PageInfoGQL { | ||||
|   hasNextPage: Boolean! | ||||
|   endCursor: String | ||||
| } | ||||
|  | ||||
| input VideoFilterInput { | ||||
|   isStreamCompleted: Boolean = null | ||||
|   requireCursorCompletion: Boolean! = true | ||||
| } | ||||
|  | ||||
| type TagGQL { | ||||
|   name: String! | ||||
|   id: Int! | ||||
|   group: String | ||||
| } | ||||
|  | ||||
| """ | ||||
| @@ -900,21 +656,6 @@ scalar JSON | ||||
| type Mutation { | ||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||
|   setLoggerLevel(path: String!, level: String!): Boolean! | ||||
|   reactToVideo(videoId: Int!, reaction: ReactionEnum): Boolean! | ||||
|   commentOnVideo( | ||||
|     videoId: Int! | ||||
|     message: String! | ||||
|     parentCommentId: Int | ||||
|   ): Boolean! | ||||
|   editComment(videoId: Int!, commentId: Int!, newMessage: String!): Boolean! | ||||
|   deleteComment(videoId: Int!, commentId: Int!): Boolean! | ||||
|   blockContent(videoId: Int!): Boolean! | ||||
|   blockUser(userId: Int!): Boolean! | ||||
|   reportContent( | ||||
|     videoId: Int! | ||||
|     reason: ReportReasonEnum! | ||||
|     customReason: String = null | ||||
|   ): Boolean! | ||||
|   addAnnotationToShot( | ||||
|     shotId: Int! | ||||
|     annotationName: String! | ||||
| @@ -924,10 +665,6 @@ type Mutation { | ||||
|     shotId: Int! | ||||
|     annotations: [UpdateAnnotationInputGQL!]! | ||||
|   ): UpdateShotAnnotationReturn! | ||||
|   editShot( | ||||
|     shotId: Int! | ||||
|     fieldsToEdit: EditableShotFieldInputGQL! | ||||
|   ): EditShotReturn! | ||||
|   getProfileImageUploadLink( | ||||
|     fileExt: String = ".png" | ||||
|   ): GetProfileUploadLinkReturn! | ||||
| @@ -935,11 +672,6 @@ type Mutation { | ||||
|   editUser(input: EditUserInputGQL!): UserGQL! | ||||
|   followUser(followedUserId: Int!): UserGQL! | ||||
|   unfollowUser(followedUserId: Int!): UserGQL! | ||||
|   retireTags(tagIds: [Int!]!): Boolean! | ||||
|   ensureStripeCustomerExists: UserGQL! | ||||
|   deleteUser: Boolean! | ||||
|   createSubscription(priceId: String!): CreateSubscriptionResultGQL! | ||||
|   cancelSubscription: UserSubscriptionStatusGQL! | ||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL | ||||
|   createUploadStream( | ||||
|     videoMetadata: VideoMetadataInput! | ||||
| @@ -953,7 +685,6 @@ type Mutation { | ||||
|   ): Boolean! | ||||
|   editUploadStream(videoId: Int!, videoMetadata: VideoMetadataInput!): Boolean! | ||||
|   deleteVideo(videoId: Int!): Boolean! | ||||
|   deleteTags(videoId: Int!, tagsToDelete: [VideoTagInput!]!): Boolean! | ||||
| } | ||||
|  | ||||
| input CreateBucketSetInput { | ||||
| @@ -962,15 +693,6 @@ input CreateBucketSetInput { | ||||
|   buckets: [BucketInputGQL!]! | ||||
| } | ||||
|  | ||||
| enum ReportReasonEnum { | ||||
|   SPAM | ||||
|   NUDITY | ||||
|   VIOLENCE | ||||
|   HATE | ||||
|   COPYRIGHT | ||||
|   OTHER | ||||
| } | ||||
|  | ||||
| type AddShotAnnotationReturn { | ||||
|   value: SuccessfulAddAddShotAnnotationErrors! | ||||
| } | ||||
| @@ -1010,22 +732,6 @@ input UpdateAnnotationInputGQL { | ||||
|   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 { | ||||
|   value: UploadLinkGetProfileUploadLinkErrors! | ||||
| } | ||||
| @@ -1056,12 +762,6 @@ input EditUserInputGQL { | ||||
|   username: String = null | ||||
|   fargoRating: Int = null | ||||
|   videosPrivateByDefault: Boolean = null | ||||
|   agreesToMarketing: Boolean = null | ||||
| } | ||||
|  | ||||
| type CreateSubscriptionResultGQL { | ||||
|   checkoutUrl: String! | ||||
|   sessionId: String! | ||||
| } | ||||
|  | ||||
| type CreateUploadStreamReturn { | ||||
| @@ -1073,18 +773,11 @@ input VideoMetadataInput { | ||||
|   startTime: DateTime = null | ||||
|   endTime: DateTime = 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 | ||||
|   lastIntendedSegmentBound: Int = null | ||||
|   streamSegmentType: StreamSegmentTypeEnum = null | ||||
|   private: Boolean = null | ||||
|   endStream: Boolean! = false | ||||
|   clientUploadStatus: ClientUploadStatusEnum = null | ||||
|   resolution: VideoResolution = null | ||||
|   framesPerSecond: Float = null | ||||
| } | ||||
|   | ||||
							
								
								
									
										18
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -10,10 +10,10 @@ | ||||
|     "@jridgewell/gen-mapping" "^0.3.0" | ||||
|     "@jridgewell/trace-mapping" "^0.3.9" | ||||
|  | ||||
| "@apollo/client@^3.11.10": | ||||
|   version "3.12.3" | ||||
|   resolved "https://registry.yarnpkg.com/@apollo/client/-/client-3.12.3.tgz#0d252749baad8328e06883fe118dc7e73e3bbb1f" | ||||
|   integrity sha512-KZ5zymRdb8bMbGUb1wP2U04ff7qIGgaC1BCdCVC+IPFiXkxEhHBc5fDEQOwAUT+vUo9KbBh3g7QK/JCOswn59w== | ||||
| "@apollo/client@^3.9.2": | ||||
|   version "3.9.2" | ||||
|   resolved "https://registry.yarnpkg.com/@apollo/client/-/client-3.9.2.tgz#96edf2c212f828bad1ef3d84234fa473c5a27ff8" | ||||
|   integrity sha512-Zw9WvXjqhpbgkvAvnj52vstOWwM0iedKWtn1hSq1cODQyoe1CF2uFwMYFI7l56BrAY9CzLi6MQA0AhxpgJgvxw== | ||||
|   dependencies: | ||||
|     "@graphql-typed-document-node/core" "^3.1.1" | ||||
|     "@wry/caches" "^1.0.0" | ||||
| @@ -23,7 +23,7 @@ | ||||
|     hoist-non-react-statics "^3.3.2" | ||||
|     optimism "^0.18.0" | ||||
|     prop-types "^15.7.2" | ||||
|     rehackt "^0.1.0" | ||||
|     rehackt "0.0.3" | ||||
|     response-iterator "^0.2.6" | ||||
|     symbol-observable "^4.0.0" | ||||
|     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" | ||||
|   integrity sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw== | ||||
|  | ||||
| rehackt@^0.1.0: | ||||
|   version "0.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/rehackt/-/rehackt-0.1.0.tgz#a7c5e289c87345f70da8728a7eb878e5d03c696b" | ||||
|   integrity sha512-7kRDOuLHB87D/JESKxQoRwv4DzbIdwkAGQ7p6QKGdVlY1IZheUnVhlk/4UZlNUVxdAXpyxikE3URsG067ybVzw== | ||||
| rehackt@0.0.3: | ||||
|   version "0.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/rehackt/-/rehackt-0.0.3.tgz#1ea454620d4641db8342e2db44595cf0e7ac6aa0" | ||||
|   integrity sha512-aBRHudKhOWwsTvCbSoinzq+Lej/7R8e8UoPvLZo5HirZIIBLGAgdG7SL9QpdcBoQ7+3QYPi3lRLknAzXBlhZ7g== | ||||
|  | ||||
| relay-runtime@12.0.0: | ||||
|   version "12.0.0" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user