Compare commits
	
		
			40 Commits
		
	
	
		
			kat/suppor
			...
			15b307a88f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 15b307a88f | |||
| 72b338bfc2 | |||
| 267486774c | |||
| b94a568ef1 | |||
| b773ccfc8f | |||
| fd5c28e073 | |||
| 4c232829b6 | |||
| ddf1036009 | |||
| 9b3e5c23a0 | |||
| a7eae9d46b | |||
| 8c3e9d6273 | |||
| f306cc6c16 | |||
| 643cdb29e3 | |||
| 89287a0100 | |||
| f9b02f65e0 | |||
| 41169e2848 | |||
| ba36bc709c | |||
| 4005416233 | |||
| db4a6315cd | |||
| af38fdea64 | |||
| 172df69340 | |||
| a030a0ef16 | |||
| 7a6cc2739f | |||
| 41c9701e18 | |||
| 16e79ed608 | |||
| f401e1879b | |||
| 72b451d322 | |||
| 5350c46e0a | |||
| 1f5c5774e1 | |||
| 3b29502e7e | |||
| abc7e9fd05 | |||
| dd5ce77102 | |||
| dabaa3d1e1 | |||
| a6604a3a6d | |||
| 09a3e0e294 | |||
| f20ca53a2a | |||
| a2b912500c | |||
| 7de3d196ba | |||
| 6d5669aaf8 | |||
| 2c583509a2 | 
							
								
								
									
										485
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										485
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -4,5 +4,6 @@ query getDeployedConfig { | ||||
|     devMode | ||||
|     environment | ||||
|     firebase | ||||
|     minimumAllowedAppVersion | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ query GetFeed( | ||||
|       stream { | ||||
|         isCompleted | ||||
|       } | ||||
|       tableSize | ||||
|       tags { | ||||
|         tagClasses { | ||||
|           name | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| query GetShots( | ||||
|   $filterInput: FilterInput! | ||||
|   $shotsPagination: GetShotsPagination = null | ||||
|   $shotsPagination: GetShotsPagination | ||||
|   $limit: Int | ||||
|   $includeCreatedAt: Boolean! = false | ||||
|   $includeUpdatedAt: Boolean! = false | ||||
| @@ -9,6 +9,7 @@ query GetShots( | ||||
|   $includeCueObjectDistance: Boolean! = false | ||||
|   $includeCueObjectAngle: Boolean! = false | ||||
|   $includeCueBallSpeed: Boolean! = false | ||||
|   $includeSpinType: Boolean! = false | ||||
|   $includeShotDirection: Boolean! = false | ||||
|   $includeTargetPocketDistance: Boolean! = false | ||||
|   $includeMake: Boolean! = false | ||||
| @@ -27,6 +28,14 @@ query GetShots( | ||||
|       id | ||||
|     } | ||||
|     falsePositiveScore | ||||
|     video { | ||||
|       stream { | ||||
|         resolution { | ||||
|           width | ||||
|           height | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     createdAt @include(if: $includeCreatedAt) | ||||
|     updatedAt @include(if: $includeUpdatedAt) | ||||
|     cueObjectFeatures @include(if: $includeCueObjectFeatures) { | ||||
| @@ -34,6 +43,7 @@ query GetShots( | ||||
|       cueObjectAngle @include(if: $includeCueObjectAngle) | ||||
|       cueBallSpeed @include(if: $includeCueBallSpeed) | ||||
|       shotDirection @include(if: $includeShotDirection) | ||||
|       spinType @include(if: $includeSpinType) | ||||
|     } | ||||
|     pocketingIntentionFeatures | ||||
|       @include(if: $includePocketingIntentionFeatures) { | ||||
| @@ -44,6 +54,18 @@ query GetShots( | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetSerializedShotPaths($filterInput: FilterInput!) { | ||||
|   getShots(filterInput: $filterInput) { | ||||
|     id | ||||
|     videoId | ||||
|     startFrame | ||||
|     endFrame | ||||
|     serializedShotPaths { | ||||
|       b64EncodedBuffer | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| query GetShotAnnotationTypes { | ||||
|   getShotAnnotationTypes { | ||||
|     id | ||||
|   | ||||
| @@ -1,11 +1,22 @@ | ||||
| mutation getProfileImageUploadLink($fileExt: String = ".png") { | ||||
|   getProfileImageUploadLink(fileExt: $fileExt) { | ||||
|     value { | ||||
|       ... on UploadLink { | ||||
|         uploadUrl | ||||
|         headers { | ||||
|           key | ||||
|           value | ||||
|         } | ||||
|       } | ||||
|       ... on GetProfileUploadLinkErrors { | ||||
|         error { | ||||
|           ... on TooManyProfileImageUploadsErr { | ||||
|             linksRequested | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation editProfileImageUri($profileImageUri: String!) { | ||||
|   | ||||
| @@ -70,6 +70,7 @@ query GetVideoUpdatePageDetails($videoId: Int!) { | ||||
|     totalShots | ||||
|     makePercentage | ||||
|     elapsedTime | ||||
|     tableSize | ||||
|     tags { | ||||
|       tagClasses { | ||||
|         name | ||||
| @@ -98,6 +99,7 @@ query GetVideoDetails($videoId: Int!) { | ||||
|     totalShotsMade | ||||
|     createdAt | ||||
|     updatedAt | ||||
|     tableSize | ||||
|     owner { | ||||
|       id | ||||
|       firebaseUid | ||||
| @@ -116,11 +118,10 @@ query GetVideoDetails($videoId: Int!) { | ||||
| query GetVideos($videoIds: [Int!]!) { | ||||
|   getVideos(videoIds: $videoIds) { | ||||
|     id | ||||
|     playlist { | ||||
|       segmentDurations | ||||
|     } | ||||
|     framesPerSecond | ||||
|     stream { | ||||
|       id | ||||
|       streamSegmentType | ||||
|       segments { | ||||
|         uploaded | ||||
|         valid | ||||
| @@ -129,6 +130,9 @@ query GetVideos($videoIds: [Int!]!) { | ||||
|         framesPerSecond | ||||
|       } | ||||
|     } | ||||
|     playlist { | ||||
|       segmentDurations | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -6,22 +6,65 @@ mutation CreateUploadStream($videoMetadataInput: VideoMetadataInput!) { | ||||
|  | ||||
| mutation GetUploadLink($videoId: Int!, $segmentIndex: Int!) { | ||||
|   getUploadLink(videoId: $videoId, segmentIndex: $segmentIndex) { | ||||
|     value { | ||||
|       ... on UploadLink { | ||||
|         uploadUrl | ||||
|         headers { | ||||
|           key | ||||
|           value | ||||
|         } | ||||
|       } | ||||
|       ... on GetUploadLinkErrors { | ||||
|         error { | ||||
|           ... on MustHaveSetForUploadLinkErr { | ||||
|             resolution | ||||
|             framesPerSecond | ||||
|           } | ||||
|           ... on SegmentAlreadyUploadedErr { | ||||
|             segmentId | ||||
|           } | ||||
|           ... on ProcessingFailedErr { | ||||
|             processing { | ||||
|               status | ||||
|               errors { | ||||
|                 message | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     stream { | ||||
|       uploadCompletionCursor | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation GetHlsInitUploadLink($videoId: Int!) { | ||||
|   getHlsInitUploadLink(videoId: $videoId) { | ||||
|     value { | ||||
|       ... on UploadLink { | ||||
|         uploadUrl | ||||
|         headers { | ||||
|           key | ||||
|           value | ||||
|         } | ||||
|       } | ||||
|       ... on GetUploadLinkErrors { | ||||
|         error { | ||||
|           ... on NoInitForChunkedUploadErr { | ||||
|             segmentType | ||||
|           } | ||||
|           ... on InitUploadAlreadyCompletedErr { | ||||
|             segmentType | ||||
|           } | ||||
|           ... on TooManyInitUploadsErr { | ||||
|             linksRequested | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| mutation SetSegmentDuration( | ||||
|   | ||||
							
								
								
									
										135
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										135
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -9,12 +9,17 @@ type Query { | ||||
|     videoId: ID! | ||||
|     intervalDuration: Int! = 300 | ||||
|   ): [MakePercentageIntervalGQL!]! | ||||
|   getShotsWithMetadata( | ||||
|     filterInput: FilterInput! | ||||
|     shotsPagination: GetShotsPagination = null | ||||
|     limit: Int! = 500 | ||||
|   ): GetShotsResult! | ||||
|   getShots( | ||||
|     filterInput: FilterInput! | ||||
|     shotsPagination: GetShotsPagination = null | ||||
|     limit: Int! = 500 | ||||
|   ): [ShotGQL!]! | ||||
|   getShotAnnotationTypes: [ShotAnnotationTypeGQL!]! | ||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||
|   getUser(userId: Int!): UserGQL | ||||
|   getLoggedInUser: UserGQL | ||||
|   getUsernames( | ||||
| @@ -96,20 +101,24 @@ input FilterInput @oneOf { | ||||
|   isLeftMiss: [Boolean!] | ||||
|   isRightMiss: [Boolean!] | ||||
|   isDirect: [Boolean!] | ||||
|   tableSize: RangeFilter | ||||
|   bankAngle: RangeFilter | ||||
|   bankDistance: RangeFilter | ||||
|   kickAngle: RangeFilter | ||||
|   kickDistance: RangeFilter | ||||
|   cueAngleAfterObject: RangeFilter | ||||
|   spinType: [SpinTypeEnum!] | ||||
|   cueSpeedAfterObject: RangeFilter | ||||
|   spinType: [String!] | ||||
|   falsePositiveScore: RangeFilter | ||||
| } | ||||
|  | ||||
| input RangeFilter { | ||||
|   lessThan: Float = null | ||||
|   greaterThanEqualTo: Float = null | ||||
|   greaterThan: Float = null | ||||
|   includeOnNone: Boolean! = false | ||||
|   lessThanInclusive: Boolean! = false | ||||
|   greaterThanInclusive: Boolean! = true | ||||
| } | ||||
|  | ||||
| enum PocketEnum { | ||||
| @@ -136,6 +145,13 @@ input ShotAnnotationInput { | ||||
|   name: String! | ||||
| } | ||||
|  | ||||
| enum SpinTypeEnum { | ||||
|   DRAW | ||||
|   FOLLOW | ||||
|   CENTER | ||||
|   UNKNOWN | ||||
| } | ||||
|  | ||||
| type BucketSetGQL { | ||||
|   keyName: String! | ||||
|   feature: String! | ||||
| @@ -152,6 +168,7 @@ type DeployedConfigGQL { | ||||
|   firebase: Boolean! | ||||
|   devMode: Boolean! | ||||
|   environment: String! | ||||
|   minimumAllowedAppVersion: String! | ||||
| } | ||||
|  | ||||
| type MakePercentageIntervalGQL { | ||||
| @@ -159,6 +176,11 @@ type MakePercentageIntervalGQL { | ||||
|   elapsedTime: Float! | ||||
| } | ||||
|  | ||||
| type GetShotsResult { | ||||
|   shots: [ShotGQL!]! | ||||
|   count: Int | ||||
| } | ||||
|  | ||||
| type ShotGQL { | ||||
|   id: Int! | ||||
|   videoId: Int! | ||||
| @@ -186,6 +208,7 @@ type CueObjectFeaturesGQL { | ||||
|   cueObjectAngle: Float | ||||
|   cueBallSpeed: Float | ||||
|   shotDirection: ShotDirectionEnum | ||||
|   spinType: SpinTypeEnum | ||||
| } | ||||
|  | ||||
| type PocketingIntentionFeaturesGQL { | ||||
| @@ -226,6 +249,7 @@ type ShotAnnotationGQL { | ||||
|   type: ShotAnnotationTypeGQL! | ||||
|   creator: UserGQL! | ||||
|   notes: String! | ||||
|   errorDefault: Boolean! | ||||
|   createdAt: DateTime | ||||
|   updatedAt: DateTime | ||||
| } | ||||
| @@ -252,9 +276,11 @@ type VideoGQL { | ||||
|   endTime: DateTime | ||||
|   elapsedTime: Float | ||||
|   framesPerSecond: Float! | ||||
|   tableSize: Float! | ||||
|   stream: UploadStreamGQL | ||||
|   playlist: HLSPlaylistGQL | ||||
|   tags: [VideoTag!]! | ||||
|   currentHomography: HomographyInfoGQL | ||||
|   homographyHistory: [HomographyInfoGQL!]! | ||||
|   currentProcessing: VideoProcessingGQL | ||||
| } | ||||
| @@ -428,8 +454,14 @@ scalar JSON | ||||
| type Mutation { | ||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||
|   setLoggerLevel(path: String!, level: String!): Boolean! | ||||
|   addAnnotationToShot(shotId: Int!, annotationName: String!): Boolean! | ||||
|   getProfileImageUploadLink(fileExt: String = ".png"): GetUploadLinkReturn! | ||||
|   addAnnotationToShot( | ||||
|     shotId: Int! | ||||
|     annotationName: String! | ||||
|     notes: String = null | ||||
|   ): AddShotAnnotationReturn! | ||||
|   getProfileImageUploadLink( | ||||
|     fileExt: String = ".png" | ||||
|   ): GetProfileUploadLinkReturn! | ||||
|   editProfileImageUri(profileImageUri: String!): UserGQL! | ||||
|   createUploadStream( | ||||
|     videoMetadata: VideoMetadataInput! | ||||
| @@ -451,10 +483,46 @@ input CreateBucketSetInput { | ||||
|   buckets: [BucketInputGQL!]! | ||||
| } | ||||
|  | ||||
| type GetUploadLinkReturn { | ||||
| type AddShotAnnotationReturn { | ||||
|   value: SuccessfulAddAddShotAnnotationErrors! | ||||
| } | ||||
|  | ||||
| union SuccessfulAddAddShotAnnotationErrors = | ||||
|     SuccessfulAdd | ||||
|   | AddShotAnnotationErrors | ||||
|  | ||||
| type SuccessfulAdd { | ||||
|   value: Boolean! | ||||
| } | ||||
|  | ||||
| type AddShotAnnotationErrors { | ||||
|   error: DoesNotOwnShotErrOtherErrorNeedsNote! | ||||
| } | ||||
|  | ||||
| union DoesNotOwnShotErrOtherErrorNeedsNote = | ||||
|     DoesNotOwnShotErr | ||||
|   | OtherErrorNeedsNote | ||||
|  | ||||
| type DoesNotOwnShotErr { | ||||
|   shotId: Int! | ||||
|   msg: String | ||||
| } | ||||
|  | ||||
| type OtherErrorNeedsNote { | ||||
|   msg: String | ||||
| } | ||||
|  | ||||
| type GetProfileUploadLinkReturn { | ||||
|   value: UploadLinkGetProfileUploadLinkErrors! | ||||
| } | ||||
|  | ||||
| union UploadLinkGetProfileUploadLinkErrors = | ||||
|     UploadLink | ||||
|   | GetProfileUploadLinkErrors | ||||
|  | ||||
| type UploadLink { | ||||
|   uploadUrl: String! | ||||
|   headers: [Header]! | ||||
|   uploadCompletionCursor: Int | ||||
| } | ||||
|  | ||||
| type Header { | ||||
| @@ -462,6 +530,14 @@ type Header { | ||||
|   value: String! | ||||
| } | ||||
|  | ||||
| type GetProfileUploadLinkErrors { | ||||
|   error: TooManyProfileImageUploadsErr! | ||||
| } | ||||
|  | ||||
| type TooManyProfileImageUploadsErr { | ||||
|   linksRequested: Int! | ||||
| } | ||||
|  | ||||
| type CreateUploadStreamReturn { | ||||
|   videoId: Int! | ||||
| } | ||||
| @@ -471,7 +547,7 @@ input VideoMetadataInput { | ||||
|   startTime: DateTime = null | ||||
|   endTime: DateTime = null | ||||
|   gameType: String = null | ||||
|   tableSize: String = null | ||||
|   tableSize: Float = null | ||||
|   uploadStreamMetadataInput: UploadStreamMetadataInput = null | ||||
|   lastIntendedSegmentBound: Int = null | ||||
|   streamSegmentType: StreamSegmentTypeEnum = null | ||||
| @@ -502,3 +578,48 @@ input VideoResolution { | ||||
|   width: Int! | ||||
|   height: Int! | ||||
| } | ||||
|  | ||||
| type GetUploadLinkReturn { | ||||
|   value: UploadLinkGetUploadLinkErrors! | ||||
|   stream: UploadStreamGQL | ||||
| } | ||||
|  | ||||
| union UploadLinkGetUploadLinkErrors = UploadLink | GetUploadLinkErrors | ||||
|  | ||||
| type GetUploadLinkErrors { | ||||
|   error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr! | ||||
| } | ||||
|  | ||||
| union MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr = | ||||
|     MustHaveSetForUploadLinkErr | ||||
|   | SegmentAlreadyUploadedErr | ||||
|   | ProcessingFailedErr | ||||
|   | NoInitForChunkedUploadErr | ||||
|   | TooManyProfileImageUploadsErr | ||||
|   | InitUploadAlreadyCompletedErr | ||||
|   | TooManyInitUploadsErr | ||||
|  | ||||
| type MustHaveSetForUploadLinkErr { | ||||
|   resolution: Boolean | ||||
|   framesPerSecond: Boolean | ||||
| } | ||||
|  | ||||
| type SegmentAlreadyUploadedErr { | ||||
|   segmentId: Int! | ||||
| } | ||||
|  | ||||
| type ProcessingFailedErr { | ||||
|   processing: VideoProcessingGQL! | ||||
| } | ||||
|  | ||||
| type NoInitForChunkedUploadErr { | ||||
|   segmentType: StreamSegmentTypeEnum! | ||||
| } | ||||
|  | ||||
| type InitUploadAlreadyCompletedErr { | ||||
|   segmentType: StreamSegmentTypeEnum! | ||||
| } | ||||
|  | ||||
| type TooManyInitUploadsErr { | ||||
|   linksRequested: Int! | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user