Compare commits
	
		
			39 Commits
		
	
	
		
			a030a0ef16
			...
			update
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 647ef3049b | |||
| 7b48a5b6e2 | |||
| ec2e3da513 | |||
| 72729e410b | |||
| 5a9205a9b8 | |||
| a33601158f | |||
| 3c6b37b567 | |||
| 9b18ada78d | |||
| d57bb607e4 | |||
| 1f88ee4a0c | |||
| a32317e72f | |||
| b60cbe3854 | |||
| e0b150aa2a | |||
| 2bdfcb994e | |||
| d5c6014548 | |||
| de6fcacfd0 | |||
| 
						 | 
					993f62b6cf | ||
| aabd74d7d7 | |||
| 15b307a88f | |||
| 72b338bfc2 | |||
| 267486774c | |||
| b94a568ef1 | |||
| b773ccfc8f | |||
| fd5c28e073 | |||
| 4c232829b6 | |||
| ddf1036009 | |||
| 9b3e5c23a0 | |||
| a7eae9d46b | |||
| 8c3e9d6273 | |||
| f306cc6c16 | |||
| 643cdb29e3 | |||
| 89287a0100 | |||
| f9b02f65e0 | |||
| 41169e2848 | |||
| ba36bc709c | |||
| 4005416233 | |||
| db4a6315cd | |||
| af38fdea64 | |||
| 172df69340 | 
@@ -13,13 +13,15 @@ _sym_db = _symbol_database.Default()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\nshot.proto\x12\x0fserialized_shot\"?\n\x03\x42ox\x12\x0c\n\x04left\x18\x01 \x01(\x02\x12\x0b\n\x03top\x18\x02 \x01(\x02\x12\r\n\x05width\x18\x03 \x01(\x02\x12\x0e\n\x06height\x18\x04 \x01(\x02\"\x1d\n\x05Point\x12\t\n\x01x\x18\x01 \x01(\x02\x12\t\n\x01y\x18\x02 \x01(\x02\"\x7f\n\rBallDetection\x12.\n\x0eplane_position\x18\x01 \x01(\x0b\x32\x16.serialized_shot.Point\x12(\n\nannotation\x18\x02 \x01(\x0b\x32\x14.serialized_shot.Box\x12\x14\n\x0cinterpolated\x18\x03 \x01(\x08\"T\n\x10RLEBallDetection\x12\x31\n\tdetection\x18\x01 \x01(\x0b\x32\x1e.serialized_shot.BallDetection\x12\r\n\x05\x63ount\x18\x02 \x01(\r\"L\n\x13RLEDetectionHistory\x12\x35\n\ndetections\x18\x01 \x03(\x0b\x32!.serialized_shot.RLEBallDetection\"F\n\x10\x44\x65tectionHistory\x12\x32\n\ndetections\x18\x01 \x03(\x0b\x32\x1e.serialized_shot.BallDetection\"\xe6\x01\n\x04Path\x12\x13\n\x0bstart_frame\x18\x01 \x01(\r\x12\x11\n\tend_frame\x18\x02 \x01(\r\x12\x37\n\ndetections\x18\x03 \x01(\x0b\x32!.serialized_shot.DetectionHistoryH\x00\x12>\n\x0erle_detections\x18\x04 \x01(\x0b\x32$.serialized_shot.RLEDetectionHistoryH\x00\x12\x15\n\x0bnot_present\x18\x05 \x01(\x08H\x00\x12\x11\n\tis_static\x18\x06 \x01(\x08\x42\x13\n\x11\x64\x65tection_history\"R\n\x11IdentifierHistory\x12\x17\n\x0f\x62\x61ll_identifier\x18\x01 \x01(\r\x12$\n\x05paths\x18\x02 \x03(\x0b\x32\x15.serialized_shot.Path\"H\n\x04Shot\x12@\n\x14identifier_histories\x18\x03 \x03(\x0b\x32\".serialized_shot.IdentifierHistoryb\x06proto3')
 | 
					DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\nshot.proto\x12\x0fserialized_shot\"?\n\x03\x42ox\x12\x0c\n\x04left\x18\x01 \x01(\x02\x12\x0b\n\x03top\x18\x02 \x01(\x02\x12\r\n\x05width\x18\x03 \x01(\x02\x12\x0e\n\x06height\x18\x04 \x01(\x02\"\x1d\n\x05Point\x12\t\n\x01x\x18\x01 \x01(\x02\x12\t\n\x01y\x18\x02 \x01(\x02\"\x7f\n\rBallDetection\x12.\n\x0eplane_position\x18\x01 \x01(\x0b\x32\x16.serialized_shot.Point\x12(\n\nannotation\x18\x02 \x01(\x0b\x32\x14.serialized_shot.Box\x12\x14\n\x0cinterpolated\x18\x03 \x01(\x08\"T\n\x10RLEBallDetection\x12\x31\n\tdetection\x18\x01 \x01(\x0b\x32\x1e.serialized_shot.BallDetection\x12\r\n\x05\x63ount\x18\x02 \x01(\r\"L\n\x13RLEDetectionHistory\x12\x35\n\ndetections\x18\x01 \x03(\x0b\x32!.serialized_shot.RLEBallDetection\"F\n\x10\x44\x65tectionHistory\x12\x32\n\ndetections\x18\x01 \x03(\x0b\x32\x1e.serialized_shot.BallDetection\"\xfc\x01\n\rCollisionInfo\x12\x0e\n\x06source\x18\x01 \x01(\r\x12M\n\x10\x62\x61ll_identifiers\x18\x02 \x03(\x0b\x32\x33.serialized_shot.CollisionInfo.BallIdentifiersEntry\x12\x17\n\x0fwall_identifier\x18\x03 \x01(\r\x12\x13\n\x0b\x66rame_index\x18\x04 \x01(\r\x12\x0e\n\x06static\x18\x05 \x01(\x08\x1aN\n\x14\x42\x61llIdentifiersEntry\x12\x0b\n\x03key\x18\x01 \x01(\r\x12%\n\x05value\x18\x02 \x01(\x0b\x32\x16.serialized_shot.Point:\x02\x38\x01\"\xcc\x02\n\x04Path\x12\x13\n\x0bstart_frame\x18\x01 \x01(\r\x12\x11\n\tend_frame\x18\x02 \x01(\r\x12\x37\n\ndetections\x18\x03 \x01(\x0b\x32!.serialized_shot.DetectionHistoryH\x00\x12>\n\x0erle_detections\x18\x04 \x01(\x0b\x32$.serialized_shot.RLEDetectionHistoryH\x00\x12\x15\n\x0bnot_present\x18\x05 \x01(\x08H\x00\x12\x11\n\tis_static\x18\x06 \x01(\x08\x12\x32\n\nstart_info\x18\x07 \x01(\x0b\x32\x1e.serialized_shot.CollisionInfo\x12\x30\n\x08\x65nd_info\x18\x08 \x01(\x0b\x32\x1e.serialized_shot.CollisionInfoB\x13\n\x11\x64\x65tection_history\"R\n\x11IdentifierHistory\x12\x17\n\x0f\x62\x61ll_identifier\x18\x01 \x01(\r\x12$\n\x05paths\x18\x02 \x03(\x0b\x32\x15.serialized_shot.Path\"j\n\x12KeyBallIdentifiers\x12\x10\n\x08\x63ue_ball\x18\x01 \x01(\r\x12\x13\n\x0bobject_ball\x18\x02 \x01(\r\x12\x13\n\x0btarget_ball\x18\x03 \x01(\r\x12\x18\n\x10\x63ontact_sequence\x18\x04 \x03(\r\"\xa8\x01\n\x04Shot\x12@\n\x14identifier_histories\x18\x03 \x03(\x0b\x32\".serialized_shot.IdentifierHistory\x12\x36\n\tkey_balls\x18\x04 \x01(\x0b\x32#.serialized_shot.KeyBallIdentifiers\x12\x13\n\x0bstart_index\x18\x05 \x01(\r\x12\x11\n\tend_index\x18\x06 \x01(\rb\x06proto3')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
_globals = globals()
 | 
					_globals = globals()
 | 
				
			||||||
_builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
 | 
					_builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
 | 
				
			||||||
_builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'shot_pb2', _globals)
 | 
					_builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'shot_pb2', _globals)
 | 
				
			||||||
if _descriptor._USE_C_DESCRIPTORS == False:
 | 
					if _descriptor._USE_C_DESCRIPTORS == False:
 | 
				
			||||||
  DESCRIPTOR._options = None
 | 
					  DESCRIPTOR._options = None
 | 
				
			||||||
 | 
					  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._options = None
 | 
				
			||||||
 | 
					  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._serialized_options = b'8\001'
 | 
				
			||||||
  _globals['_BOX']._serialized_start=31
 | 
					  _globals['_BOX']._serialized_start=31
 | 
				
			||||||
  _globals['_BOX']._serialized_end=94
 | 
					  _globals['_BOX']._serialized_end=94
 | 
				
			||||||
  _globals['_POINT']._serialized_start=96
 | 
					  _globals['_POINT']._serialized_start=96
 | 
				
			||||||
@@ -32,10 +34,16 @@ if _descriptor._USE_C_DESCRIPTORS == False:
 | 
				
			|||||||
  _globals['_RLEDETECTIONHISTORY']._serialized_end=418
 | 
					  _globals['_RLEDETECTIONHISTORY']._serialized_end=418
 | 
				
			||||||
  _globals['_DETECTIONHISTORY']._serialized_start=420
 | 
					  _globals['_DETECTIONHISTORY']._serialized_start=420
 | 
				
			||||||
  _globals['_DETECTIONHISTORY']._serialized_end=490
 | 
					  _globals['_DETECTIONHISTORY']._serialized_end=490
 | 
				
			||||||
  _globals['_PATH']._serialized_start=493
 | 
					  _globals['_COLLISIONINFO']._serialized_start=493
 | 
				
			||||||
  _globals['_PATH']._serialized_end=723
 | 
					  _globals['_COLLISIONINFO']._serialized_end=745
 | 
				
			||||||
  _globals['_IDENTIFIERHISTORY']._serialized_start=725
 | 
					  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._serialized_start=667
 | 
				
			||||||
  _globals['_IDENTIFIERHISTORY']._serialized_end=807
 | 
					  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._serialized_end=745
 | 
				
			||||||
  _globals['_SHOT']._serialized_start=809
 | 
					  _globals['_PATH']._serialized_start=748
 | 
				
			||||||
  _globals['_SHOT']._serialized_end=881
 | 
					  _globals['_PATH']._serialized_end=1080
 | 
				
			||||||
 | 
					  _globals['_IDENTIFIERHISTORY']._serialized_start=1082
 | 
				
			||||||
 | 
					  _globals['_IDENTIFIERHISTORY']._serialized_end=1164
 | 
				
			||||||
 | 
					  _globals['_KEYBALLIDENTIFIERS']._serialized_start=1166
 | 
				
			||||||
 | 
					  _globals['_KEYBALLIDENTIFIERS']._serialized_end=1272
 | 
				
			||||||
 | 
					  _globals['_SHOT']._serialized_start=1275
 | 
				
			||||||
 | 
					  _globals['_SHOT']._serialized_end=1443
 | 
				
			||||||
# @@protoc_insertion_point(module_scope)
 | 
					# @@protoc_insertion_point(module_scope)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -55,21 +55,46 @@ class DetectionHistory(_message.Message):
 | 
				
			|||||||
    detections: _containers.RepeatedCompositeFieldContainer[BallDetection]
 | 
					    detections: _containers.RepeatedCompositeFieldContainer[BallDetection]
 | 
				
			||||||
    def __init__(self, detections: _Optional[_Iterable[_Union[BallDetection, _Mapping]]] = ...) -> None: ...
 | 
					    def __init__(self, detections: _Optional[_Iterable[_Union[BallDetection, _Mapping]]] = ...) -> None: ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class CollisionInfo(_message.Message):
 | 
				
			||||||
 | 
					    __slots__ = ["source", "ball_identifiers", "wall_identifier", "frame_index", "static"]
 | 
				
			||||||
 | 
					    class BallIdentifiersEntry(_message.Message):
 | 
				
			||||||
 | 
					        __slots__ = ["key", "value"]
 | 
				
			||||||
 | 
					        KEY_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					        VALUE_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					        key: int
 | 
				
			||||||
 | 
					        value: Point
 | 
				
			||||||
 | 
					        def __init__(self, key: _Optional[int] = ..., value: _Optional[_Union[Point, _Mapping]] = ...) -> None: ...
 | 
				
			||||||
 | 
					    SOURCE_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    BALL_IDENTIFIERS_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    WALL_IDENTIFIER_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    FRAME_INDEX_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    STATIC_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    source: int
 | 
				
			||||||
 | 
					    ball_identifiers: _containers.MessageMap[int, Point]
 | 
				
			||||||
 | 
					    wall_identifier: int
 | 
				
			||||||
 | 
					    frame_index: int
 | 
				
			||||||
 | 
					    static: bool
 | 
				
			||||||
 | 
					    def __init__(self, source: _Optional[int] = ..., ball_identifiers: _Optional[_Mapping[int, Point]] = ..., wall_identifier: _Optional[int] = ..., frame_index: _Optional[int] = ..., static: bool = ...) -> None: ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Path(_message.Message):
 | 
					class Path(_message.Message):
 | 
				
			||||||
    __slots__ = ["start_frame", "end_frame", "detections", "rle_detections", "not_present", "is_static"]
 | 
					    __slots__ = ["start_frame", "end_frame", "detections", "rle_detections", "not_present", "is_static", "start_info", "end_info"]
 | 
				
			||||||
    START_FRAME_FIELD_NUMBER: _ClassVar[int]
 | 
					    START_FRAME_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    END_FRAME_FIELD_NUMBER: _ClassVar[int]
 | 
					    END_FRAME_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    DETECTIONS_FIELD_NUMBER: _ClassVar[int]
 | 
					    DETECTIONS_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    RLE_DETECTIONS_FIELD_NUMBER: _ClassVar[int]
 | 
					    RLE_DETECTIONS_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    NOT_PRESENT_FIELD_NUMBER: _ClassVar[int]
 | 
					    NOT_PRESENT_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    IS_STATIC_FIELD_NUMBER: _ClassVar[int]
 | 
					    IS_STATIC_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    START_INFO_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    END_INFO_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    start_frame: int
 | 
					    start_frame: int
 | 
				
			||||||
    end_frame: int
 | 
					    end_frame: int
 | 
				
			||||||
    detections: DetectionHistory
 | 
					    detections: DetectionHistory
 | 
				
			||||||
    rle_detections: RLEDetectionHistory
 | 
					    rle_detections: RLEDetectionHistory
 | 
				
			||||||
    not_present: bool
 | 
					    not_present: bool
 | 
				
			||||||
    is_static: bool
 | 
					    is_static: bool
 | 
				
			||||||
    def __init__(self, start_frame: _Optional[int] = ..., end_frame: _Optional[int] = ..., detections: _Optional[_Union[DetectionHistory, _Mapping]] = ..., rle_detections: _Optional[_Union[RLEDetectionHistory, _Mapping]] = ..., not_present: bool = ..., is_static: bool = ...) -> None: ...
 | 
					    start_info: CollisionInfo
 | 
				
			||||||
 | 
					    end_info: CollisionInfo
 | 
				
			||||||
 | 
					    def __init__(self, start_frame: _Optional[int] = ..., end_frame: _Optional[int] = ..., detections: _Optional[_Union[DetectionHistory, _Mapping]] = ..., rle_detections: _Optional[_Union[RLEDetectionHistory, _Mapping]] = ..., not_present: bool = ..., is_static: bool = ..., start_info: _Optional[_Union[CollisionInfo, _Mapping]] = ..., end_info: _Optional[_Union[CollisionInfo, _Mapping]] = ...) -> None: ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class IdentifierHistory(_message.Message):
 | 
					class IdentifierHistory(_message.Message):
 | 
				
			||||||
    __slots__ = ["ball_identifier", "paths"]
 | 
					    __slots__ = ["ball_identifier", "paths"]
 | 
				
			||||||
@@ -79,8 +104,26 @@ class IdentifierHistory(_message.Message):
 | 
				
			|||||||
    paths: _containers.RepeatedCompositeFieldContainer[Path]
 | 
					    paths: _containers.RepeatedCompositeFieldContainer[Path]
 | 
				
			||||||
    def __init__(self, ball_identifier: _Optional[int] = ..., paths: _Optional[_Iterable[_Union[Path, _Mapping]]] = ...) -> None: ...
 | 
					    def __init__(self, ball_identifier: _Optional[int] = ..., paths: _Optional[_Iterable[_Union[Path, _Mapping]]] = ...) -> None: ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class KeyBallIdentifiers(_message.Message):
 | 
				
			||||||
 | 
					    __slots__ = ["cue_ball", "object_ball", "target_ball", "contact_sequence"]
 | 
				
			||||||
 | 
					    CUE_BALL_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    OBJECT_BALL_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    TARGET_BALL_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    CONTACT_SEQUENCE_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    cue_ball: int
 | 
				
			||||||
 | 
					    object_ball: int
 | 
				
			||||||
 | 
					    target_ball: int
 | 
				
			||||||
 | 
					    contact_sequence: _containers.RepeatedScalarFieldContainer[int]
 | 
				
			||||||
 | 
					    def __init__(self, cue_ball: _Optional[int] = ..., object_ball: _Optional[int] = ..., target_ball: _Optional[int] = ..., contact_sequence: _Optional[_Iterable[int]] = ...) -> None: ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Shot(_message.Message):
 | 
					class Shot(_message.Message):
 | 
				
			||||||
    __slots__ = ["identifier_histories"]
 | 
					    __slots__ = ["identifier_histories", "key_balls", "start_index", "end_index"]
 | 
				
			||||||
    IDENTIFIER_HISTORIES_FIELD_NUMBER: _ClassVar[int]
 | 
					    IDENTIFIER_HISTORIES_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    KEY_BALLS_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    START_INDEX_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
 | 
					    END_INDEX_FIELD_NUMBER: _ClassVar[int]
 | 
				
			||||||
    identifier_histories: _containers.RepeatedCompositeFieldContainer[IdentifierHistory]
 | 
					    identifier_histories: _containers.RepeatedCompositeFieldContainer[IdentifierHistory]
 | 
				
			||||||
    def __init__(self, identifier_histories: _Optional[_Iterable[_Union[IdentifierHistory, _Mapping]]] = ...) -> None: ...
 | 
					    key_balls: KeyBallIdentifiers
 | 
				
			||||||
 | 
					    start_index: int
 | 
				
			||||||
 | 
					    end_index: int
 | 
				
			||||||
 | 
					    def __init__(self, identifier_histories: _Optional[_Iterable[_Union[IdentifierHistory, _Mapping]]] = ..., key_balls: _Optional[_Union[KeyBallIdentifiers, _Mapping]] = ..., start_index: _Optional[int] = ..., end_index: _Optional[int] = ...) -> None: ...
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,10 +3,10 @@ syntax = "proto3";
 | 
				
			|||||||
package serialized_shot;
 | 
					package serialized_shot;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message Box {
 | 
					message Box {
 | 
				
			||||||
	float left = 1;
 | 
					  float left = 1;
 | 
				
			||||||
	float top = 2;
 | 
					  float top = 2;
 | 
				
			||||||
	float width = 3;
 | 
					  float width = 3;
 | 
				
			||||||
	float height = 4;
 | 
					  float height = 4;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message Point {
 | 
					message Point {
 | 
				
			||||||
@@ -15,40 +15,59 @@ message Point {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message BallDetection {
 | 
					message BallDetection {
 | 
				
			||||||
	Point plane_position = 1;
 | 
					  Point plane_position = 1;
 | 
				
			||||||
	Box annotation = 2;
 | 
					  Box annotation = 2;
 | 
				
			||||||
	bool interpolated = 3;
 | 
					  bool interpolated = 3;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message RLEBallDetection {
 | 
					message RLEBallDetection {
 | 
				
			||||||
	BallDetection detection = 1;
 | 
					  BallDetection detection = 1;
 | 
				
			||||||
	uint32 count = 2;
 | 
					  uint32 count = 2;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message RLEDetectionHistory {
 | 
					message RLEDetectionHistory { repeated RLEBallDetection detections = 1; }
 | 
				
			||||||
  repeated RLEBallDetection detections = 1;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
message DetectionHistory {
 | 
					message DetectionHistory { repeated BallDetection detections = 1; }
 | 
				
			||||||
  repeated BallDetection detections = 1;
 | 
					
 | 
				
			||||||
 | 
					message CollisionInfo {
 | 
				
			||||||
 | 
					  uint32 source = 1;
 | 
				
			||||||
 | 
					  map<uint32, Point> ball_identifiers = 2;
 | 
				
			||||||
 | 
					  uint32 wall_identifier = 3;
 | 
				
			||||||
 | 
					  uint32 frame_index = 4;
 | 
				
			||||||
 | 
					  bool static = 5;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message Path {
 | 
					message Path {
 | 
				
			||||||
  uint32 start_frame = 1;
 | 
					  uint32 start_frame = 1;
 | 
				
			||||||
  uint32 end_frame = 2;
 | 
					  uint32 end_frame = 2;
 | 
				
			||||||
  oneof detection_history {
 | 
					  oneof detection_history {
 | 
				
			||||||
	DetectionHistory detections = 3;
 | 
					    DetectionHistory detections = 3;
 | 
				
			||||||
	RLEDetectionHistory rle_detections = 4;
 | 
					    RLEDetectionHistory rle_detections = 4;
 | 
				
			||||||
	bool not_present = 5;
 | 
					    bool not_present = 5;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  bool is_static = 6;
 | 
					  bool is_static = 6;
 | 
				
			||||||
 | 
					  CollisionInfo start_info = 7;
 | 
				
			||||||
 | 
					  CollisionInfo end_info = 8;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message IdentifierHistory {
 | 
					message IdentifierHistory {
 | 
				
			||||||
  uint32 ball_identifier = 1;
 | 
					  uint32 ball_identifier = 1;
 | 
				
			||||||
  repeated Path paths = 2;
 | 
					  repeated Path paths = 2;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					message KeyBallIdentifiers {
 | 
				
			||||||
 | 
					  uint32 cue_ball = 1;
 | 
				
			||||||
 | 
					  uint32 object_ball = 2;
 | 
				
			||||||
 | 
					  uint32 target_ball = 3;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // For now this will just be cue->object/target->target
 | 
				
			||||||
 | 
					  // Long term this will potentially represent a linked list
 | 
				
			||||||
 | 
					  // of all balls in a shot.
 | 
				
			||||||
 | 
					  repeated uint32 contact_sequence = 4;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
message Shot {
 | 
					message Shot {
 | 
				
			||||||
  repeated IdentifierHistory identifier_histories = 3;
 | 
					  repeated IdentifierHistory identifier_histories = 3;
 | 
				
			||||||
 | 
					  KeyBallIdentifiers key_balls = 4;
 | 
				
			||||||
 | 
					  uint32 start_index = 5;
 | 
				
			||||||
 | 
					  uint32 end_index = 6;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -427,6 +427,150 @@ function _decodeDetectionHistory(bb: ByteBuffer): DetectionHistory {
 | 
				
			|||||||
  return message;
 | 
					  return message;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export interface CollisionInfo {
 | 
				
			||||||
 | 
					  source?: number;
 | 
				
			||||||
 | 
					  ball_identifiers?: { [key: number]: Point };
 | 
				
			||||||
 | 
					  wall_identifier?: number;
 | 
				
			||||||
 | 
					  frame_index?: number;
 | 
				
			||||||
 | 
					  static?: boolean;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function encodeCollisionInfo(message: CollisionInfo): Uint8Array {
 | 
				
			||||||
 | 
					  let bb = popByteBuffer();
 | 
				
			||||||
 | 
					  _encodeCollisionInfo(message, bb);
 | 
				
			||||||
 | 
					  return toUint8Array(bb);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function _encodeCollisionInfo(message: CollisionInfo, bb: ByteBuffer): void {
 | 
				
			||||||
 | 
					  // optional uint32 source = 1;
 | 
				
			||||||
 | 
					  let $source = message.source;
 | 
				
			||||||
 | 
					  if ($source !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 8);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $source);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional map<uint32, Point> ball_identifiers = 2;
 | 
				
			||||||
 | 
					  let map$ball_identifiers = message.ball_identifiers;
 | 
				
			||||||
 | 
					  if (map$ball_identifiers !== undefined) {
 | 
				
			||||||
 | 
					    for (let key in map$ball_identifiers) {
 | 
				
			||||||
 | 
					      let nested = popByteBuffer();
 | 
				
			||||||
 | 
					      let value = map$ball_identifiers[key];
 | 
				
			||||||
 | 
					      writeVarint32(nested, 8);
 | 
				
			||||||
 | 
					      writeVarint32(nested, +key);
 | 
				
			||||||
 | 
					      writeVarint32(nested, 18);
 | 
				
			||||||
 | 
					      let nestedValue = popByteBuffer();
 | 
				
			||||||
 | 
					      _encodePoint(value, nestedValue);
 | 
				
			||||||
 | 
					      writeVarint32(nested, nestedValue.limit);
 | 
				
			||||||
 | 
					      writeByteBuffer(nested, nestedValue);
 | 
				
			||||||
 | 
					      pushByteBuffer(nestedValue);
 | 
				
			||||||
 | 
					      writeVarint32(bb, 18);
 | 
				
			||||||
 | 
					      writeVarint32(bb, nested.offset);
 | 
				
			||||||
 | 
					      writeByteBuffer(bb, nested);
 | 
				
			||||||
 | 
					      pushByteBuffer(nested);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional uint32 wall_identifier = 3;
 | 
				
			||||||
 | 
					  let $wall_identifier = message.wall_identifier;
 | 
				
			||||||
 | 
					  if ($wall_identifier !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 24);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $wall_identifier);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional uint32 frame_index = 4;
 | 
				
			||||||
 | 
					  let $frame_index = message.frame_index;
 | 
				
			||||||
 | 
					  if ($frame_index !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 32);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $frame_index);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional bool static = 5;
 | 
				
			||||||
 | 
					  let $static = message.static;
 | 
				
			||||||
 | 
					  if ($static !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 40);
 | 
				
			||||||
 | 
					    writeByte(bb, $static ? 1 : 0);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function decodeCollisionInfo(binary: Uint8Array): CollisionInfo {
 | 
				
			||||||
 | 
					  return _decodeCollisionInfo(wrapByteBuffer(binary));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function _decodeCollisionInfo(bb: ByteBuffer): CollisionInfo {
 | 
				
			||||||
 | 
					  let message: CollisionInfo = {} as any;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  end_of_message: while (!isAtEnd(bb)) {
 | 
				
			||||||
 | 
					    let tag = readVarint32(bb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    switch (tag >>> 3) {
 | 
				
			||||||
 | 
					      case 0:
 | 
				
			||||||
 | 
					        break end_of_message;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 source = 1;
 | 
				
			||||||
 | 
					      case 1: {
 | 
				
			||||||
 | 
					        message.source = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional map<uint32, Point> ball_identifiers = 2;
 | 
				
			||||||
 | 
					      case 2: {
 | 
				
			||||||
 | 
					        let values =
 | 
				
			||||||
 | 
					          message.ball_identifiers || (message.ball_identifiers = {});
 | 
				
			||||||
 | 
					        let outerLimit = pushTemporaryLength(bb);
 | 
				
			||||||
 | 
					        let key: number | undefined;
 | 
				
			||||||
 | 
					        let value: Point | undefined;
 | 
				
			||||||
 | 
					        end_of_entry: while (!isAtEnd(bb)) {
 | 
				
			||||||
 | 
					          let tag = readVarint32(bb);
 | 
				
			||||||
 | 
					          switch (tag >>> 3) {
 | 
				
			||||||
 | 
					            case 0:
 | 
				
			||||||
 | 
					              break end_of_entry;
 | 
				
			||||||
 | 
					            case 1: {
 | 
				
			||||||
 | 
					              key = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					              break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            case 2: {
 | 
				
			||||||
 | 
					              let valueLimit = pushTemporaryLength(bb);
 | 
				
			||||||
 | 
					              value = _decodePoint(bb);
 | 
				
			||||||
 | 
					              bb.limit = valueLimit;
 | 
				
			||||||
 | 
					              break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            default:
 | 
				
			||||||
 | 
					              skipUnknownField(bb, tag & 7);
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (key === undefined || value === undefined)
 | 
				
			||||||
 | 
					          throw new Error("Invalid data for map: ball_identifiers");
 | 
				
			||||||
 | 
					        values[key] = value;
 | 
				
			||||||
 | 
					        bb.limit = outerLimit;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 wall_identifier = 3;
 | 
				
			||||||
 | 
					      case 3: {
 | 
				
			||||||
 | 
					        message.wall_identifier = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 frame_index = 4;
 | 
				
			||||||
 | 
					      case 4: {
 | 
				
			||||||
 | 
					        message.frame_index = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional bool static = 5;
 | 
				
			||||||
 | 
					      case 5: {
 | 
				
			||||||
 | 
					        message.static = !!readByte(bb);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      default:
 | 
				
			||||||
 | 
					        skipUnknownField(bb, tag & 7);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return message;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export interface Path {
 | 
					export interface Path {
 | 
				
			||||||
  start_frame?: number;
 | 
					  start_frame?: number;
 | 
				
			||||||
  end_frame?: number;
 | 
					  end_frame?: number;
 | 
				
			||||||
@@ -434,6 +578,8 @@ export interface Path {
 | 
				
			|||||||
  rle_detections?: RLEDetectionHistory;
 | 
					  rle_detections?: RLEDetectionHistory;
 | 
				
			||||||
  not_present?: boolean;
 | 
					  not_present?: boolean;
 | 
				
			||||||
  is_static?: boolean;
 | 
					  is_static?: boolean;
 | 
				
			||||||
 | 
					  start_info?: CollisionInfo;
 | 
				
			||||||
 | 
					  end_info?: CollisionInfo;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function encodePath(message: Path): Uint8Array {
 | 
					export function encodePath(message: Path): Uint8Array {
 | 
				
			||||||
@@ -492,6 +638,28 @@ function _encodePath(message: Path, bb: ByteBuffer): void {
 | 
				
			|||||||
    writeVarint32(bb, 48);
 | 
					    writeVarint32(bb, 48);
 | 
				
			||||||
    writeByte(bb, $is_static ? 1 : 0);
 | 
					    writeByte(bb, $is_static ? 1 : 0);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional CollisionInfo start_info = 7;
 | 
				
			||||||
 | 
					  let $start_info = message.start_info;
 | 
				
			||||||
 | 
					  if ($start_info !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 58);
 | 
				
			||||||
 | 
					    let nested = popByteBuffer();
 | 
				
			||||||
 | 
					    _encodeCollisionInfo($start_info, nested);
 | 
				
			||||||
 | 
					    writeVarint32(bb, nested.limit);
 | 
				
			||||||
 | 
					    writeByteBuffer(bb, nested);
 | 
				
			||||||
 | 
					    pushByteBuffer(nested);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional CollisionInfo end_info = 8;
 | 
				
			||||||
 | 
					  let $end_info = message.end_info;
 | 
				
			||||||
 | 
					  if ($end_info !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 66);
 | 
				
			||||||
 | 
					    let nested = popByteBuffer();
 | 
				
			||||||
 | 
					    _encodeCollisionInfo($end_info, nested);
 | 
				
			||||||
 | 
					    writeVarint32(bb, nested.limit);
 | 
				
			||||||
 | 
					    writeByteBuffer(bb, nested);
 | 
				
			||||||
 | 
					    pushByteBuffer(nested);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function decodePath(binary: Uint8Array): Path {
 | 
					export function decodePath(binary: Uint8Array): Path {
 | 
				
			||||||
@@ -548,6 +716,22 @@ function _decodePath(bb: ByteBuffer): Path {
 | 
				
			|||||||
        break;
 | 
					        break;
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional CollisionInfo start_info = 7;
 | 
				
			||||||
 | 
					      case 7: {
 | 
				
			||||||
 | 
					        let limit = pushTemporaryLength(bb);
 | 
				
			||||||
 | 
					        message.start_info = _decodeCollisionInfo(bb);
 | 
				
			||||||
 | 
					        bb.limit = limit;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional CollisionInfo end_info = 8;
 | 
				
			||||||
 | 
					      case 8: {
 | 
				
			||||||
 | 
					        let limit = pushTemporaryLength(bb);
 | 
				
			||||||
 | 
					        message.end_info = _decodeCollisionInfo(bb);
 | 
				
			||||||
 | 
					        bb.limit = limit;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      default:
 | 
					      default:
 | 
				
			||||||
        skipUnknownField(bb, tag & 7);
 | 
					        skipUnknownField(bb, tag & 7);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -631,8 +815,123 @@ function _decodeIdentifierHistory(bb: ByteBuffer): IdentifierHistory {
 | 
				
			|||||||
  return message;
 | 
					  return message;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export interface KeyBallIdentifiers {
 | 
				
			||||||
 | 
					  cue_ball?: number;
 | 
				
			||||||
 | 
					  object_ball?: number;
 | 
				
			||||||
 | 
					  target_ball?: number;
 | 
				
			||||||
 | 
					  contact_sequence?: number[];
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function encodeKeyBallIdentifiers(
 | 
				
			||||||
 | 
					  message: KeyBallIdentifiers,
 | 
				
			||||||
 | 
					): Uint8Array {
 | 
				
			||||||
 | 
					  let bb = popByteBuffer();
 | 
				
			||||||
 | 
					  _encodeKeyBallIdentifiers(message, bb);
 | 
				
			||||||
 | 
					  return toUint8Array(bb);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function _encodeKeyBallIdentifiers(
 | 
				
			||||||
 | 
					  message: KeyBallIdentifiers,
 | 
				
			||||||
 | 
					  bb: ByteBuffer,
 | 
				
			||||||
 | 
					): void {
 | 
				
			||||||
 | 
					  // optional uint32 cue_ball = 1;
 | 
				
			||||||
 | 
					  let $cue_ball = message.cue_ball;
 | 
				
			||||||
 | 
					  if ($cue_ball !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 8);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $cue_ball);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional uint32 object_ball = 2;
 | 
				
			||||||
 | 
					  let $object_ball = message.object_ball;
 | 
				
			||||||
 | 
					  if ($object_ball !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 16);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $object_ball);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional uint32 target_ball = 3;
 | 
				
			||||||
 | 
					  let $target_ball = message.target_ball;
 | 
				
			||||||
 | 
					  if ($target_ball !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 24);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $target_ball);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // repeated uint32 contact_sequence = 4;
 | 
				
			||||||
 | 
					  let array$contact_sequence = message.contact_sequence;
 | 
				
			||||||
 | 
					  if (array$contact_sequence !== undefined) {
 | 
				
			||||||
 | 
					    let packed = popByteBuffer();
 | 
				
			||||||
 | 
					    for (let value of array$contact_sequence) {
 | 
				
			||||||
 | 
					      writeVarint32(packed, value);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    writeVarint32(bb, 34);
 | 
				
			||||||
 | 
					    writeVarint32(bb, packed.offset);
 | 
				
			||||||
 | 
					    writeByteBuffer(bb, packed);
 | 
				
			||||||
 | 
					    pushByteBuffer(packed);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function decodeKeyBallIdentifiers(
 | 
				
			||||||
 | 
					  binary: Uint8Array,
 | 
				
			||||||
 | 
					): KeyBallIdentifiers {
 | 
				
			||||||
 | 
					  return _decodeKeyBallIdentifiers(wrapByteBuffer(binary));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function _decodeKeyBallIdentifiers(bb: ByteBuffer): KeyBallIdentifiers {
 | 
				
			||||||
 | 
					  let message: KeyBallIdentifiers = {} as any;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  end_of_message: while (!isAtEnd(bb)) {
 | 
				
			||||||
 | 
					    let tag = readVarint32(bb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    switch (tag >>> 3) {
 | 
				
			||||||
 | 
					      case 0:
 | 
				
			||||||
 | 
					        break end_of_message;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 cue_ball = 1;
 | 
				
			||||||
 | 
					      case 1: {
 | 
				
			||||||
 | 
					        message.cue_ball = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 object_ball = 2;
 | 
				
			||||||
 | 
					      case 2: {
 | 
				
			||||||
 | 
					        message.object_ball = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 target_ball = 3;
 | 
				
			||||||
 | 
					      case 3: {
 | 
				
			||||||
 | 
					        message.target_ball = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // repeated uint32 contact_sequence = 4;
 | 
				
			||||||
 | 
					      case 4: {
 | 
				
			||||||
 | 
					        let values =
 | 
				
			||||||
 | 
					          message.contact_sequence || (message.contact_sequence = []);
 | 
				
			||||||
 | 
					        if ((tag & 7) === 2) {
 | 
				
			||||||
 | 
					          let outerLimit = pushTemporaryLength(bb);
 | 
				
			||||||
 | 
					          while (!isAtEnd(bb)) {
 | 
				
			||||||
 | 
					            values.push(readVarint32(bb) >>> 0);
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					          bb.limit = outerLimit;
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          values.push(readVarint32(bb) >>> 0);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      default:
 | 
				
			||||||
 | 
					        skipUnknownField(bb, tag & 7);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return message;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export interface Shot {
 | 
					export interface Shot {
 | 
				
			||||||
  identifier_histories?: IdentifierHistory[];
 | 
					  identifier_histories?: IdentifierHistory[];
 | 
				
			||||||
 | 
					  key_balls?: KeyBallIdentifiers;
 | 
				
			||||||
 | 
					  start_index?: number;
 | 
				
			||||||
 | 
					  end_index?: number;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function encodeShot(message: Shot): Uint8Array {
 | 
					export function encodeShot(message: Shot): Uint8Array {
 | 
				
			||||||
@@ -654,6 +953,31 @@ function _encodeShot(message: Shot, bb: ByteBuffer): void {
 | 
				
			|||||||
      pushByteBuffer(nested);
 | 
					      pushByteBuffer(nested);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional KeyBallIdentifiers key_balls = 4;
 | 
				
			||||||
 | 
					  let $key_balls = message.key_balls;
 | 
				
			||||||
 | 
					  if ($key_balls !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 34);
 | 
				
			||||||
 | 
					    let nested = popByteBuffer();
 | 
				
			||||||
 | 
					    _encodeKeyBallIdentifiers($key_balls, nested);
 | 
				
			||||||
 | 
					    writeVarint32(bb, nested.limit);
 | 
				
			||||||
 | 
					    writeByteBuffer(bb, nested);
 | 
				
			||||||
 | 
					    pushByteBuffer(nested);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional uint32 start_index = 5;
 | 
				
			||||||
 | 
					  let $start_index = message.start_index;
 | 
				
			||||||
 | 
					  if ($start_index !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 40);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $start_index);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // optional uint32 end_index = 6;
 | 
				
			||||||
 | 
					  let $end_index = message.end_index;
 | 
				
			||||||
 | 
					  if ($end_index !== undefined) {
 | 
				
			||||||
 | 
					    writeVarint32(bb, 48);
 | 
				
			||||||
 | 
					    writeVarint32(bb, $end_index);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function decodeShot(binary: Uint8Array): Shot {
 | 
					export function decodeShot(binary: Uint8Array): Shot {
 | 
				
			||||||
@@ -680,6 +1004,26 @@ function _decodeShot(bb: ByteBuffer): Shot {
 | 
				
			|||||||
        break;
 | 
					        break;
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional KeyBallIdentifiers key_balls = 4;
 | 
				
			||||||
 | 
					      case 4: {
 | 
				
			||||||
 | 
					        let limit = pushTemporaryLength(bb);
 | 
				
			||||||
 | 
					        message.key_balls = _decodeKeyBallIdentifiers(bb);
 | 
				
			||||||
 | 
					        bb.limit = limit;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 start_index = 5;
 | 
				
			||||||
 | 
					      case 5: {
 | 
				
			||||||
 | 
					        message.start_index = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // optional uint32 end_index = 6;
 | 
				
			||||||
 | 
					      case 6: {
 | 
				
			||||||
 | 
					        message.end_index = readVarint32(bb) >>> 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      default:
 | 
					      default:
 | 
				
			||||||
        skipUnknownField(bb, tag & 7);
 | 
					        skipUnknownField(bb, tag & 7);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										523
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										523
									
								
								src/index.tsx
									
									
									
									
									
								
							@@ -62,8 +62,13 @@ export type AggregationIdentifierGql = {
 | 
				
			|||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type AggregationInput =
 | 
					export type AggregationInput =
 | 
				
			||||||
  | { bucketSet: BucketSetInputGql; enum?: never }
 | 
					  | { bucketSet: BucketSetInputGql; datetimeRange?: never; enum?: never }
 | 
				
			||||||
  | { bucketSet?: never; enum: EnumAggregation };
 | 
					  | {
 | 
				
			||||||
 | 
					      bucketSet?: never;
 | 
				
			||||||
 | 
					      datetimeRange: DatetimeRangeAggregationInput;
 | 
				
			||||||
 | 
					      enum?: never;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  | { bucketSet?: never; datetimeRange?: never; enum: EnumAggregation };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type BankFeaturesGql = {
 | 
					export type BankFeaturesGql = {
 | 
				
			||||||
  __typename?: "BankFeaturesGQL";
 | 
					  __typename?: "BankFeaturesGQL";
 | 
				
			||||||
@@ -124,6 +129,13 @@ export type CueObjectFeaturesGql = {
 | 
				
			|||||||
  cueObjectAngle?: Maybe<Scalars["Float"]["output"]>;
 | 
					  cueObjectAngle?: Maybe<Scalars["Float"]["output"]>;
 | 
				
			||||||
  cueObjectDistance?: Maybe<Scalars["Float"]["output"]>;
 | 
					  cueObjectDistance?: Maybe<Scalars["Float"]["output"]>;
 | 
				
			||||||
  shotDirection?: Maybe<ShotDirectionEnum>;
 | 
					  shotDirection?: Maybe<ShotDirectionEnum>;
 | 
				
			||||||
 | 
					  spinType?: Maybe<SpinTypeEnum>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type DatetimeRangeAggregationInput = {
 | 
				
			||||||
 | 
					  endDatetime: Scalars["DateTime"]["input"];
 | 
				
			||||||
 | 
					  interval: TimeInterval;
 | 
				
			||||||
 | 
					  startDatetime: Scalars["DateTime"]["input"];
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type DeployedConfigGql = {
 | 
					export type DeployedConfigGql = {
 | 
				
			||||||
@@ -949,7 +961,7 @@ export type FilterInput =
 | 
				
			|||||||
      notFilter?: never;
 | 
					      notFilter?: never;
 | 
				
			||||||
      orFilters?: never;
 | 
					      orFilters?: never;
 | 
				
			||||||
      shotDirection?: never;
 | 
					      shotDirection?: never;
 | 
				
			||||||
      spinType: Array<Scalars["String"]["input"]>;
 | 
					      spinType: Array<SpinTypeEnum>;
 | 
				
			||||||
      tableSize?: never;
 | 
					      tableSize?: never;
 | 
				
			||||||
      tags?: never;
 | 
					      tags?: never;
 | 
				
			||||||
      targetPocketDistance?: never;
 | 
					      targetPocketDistance?: never;
 | 
				
			||||||
@@ -1132,9 +1144,15 @@ export type GetShotsPagination = {
 | 
				
			|||||||
  startFrameAfter: Scalars["Int"]["input"];
 | 
					  startFrameAfter: Scalars["Int"]["input"];
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetShotsResult = {
 | 
				
			||||||
 | 
					  __typename?: "GetShotsResult";
 | 
				
			||||||
 | 
					  count?: Maybe<Scalars["Int"]["output"]>;
 | 
				
			||||||
 | 
					  shots: Array<ShotGql>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type GetUploadLinkErrors = {
 | 
					export type GetUploadLinkErrors = {
 | 
				
			||||||
  __typename?: "GetUploadLinkErrors";
 | 
					  __typename?: "GetUploadLinkErrors";
 | 
				
			||||||
  error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErr;
 | 
					  error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type GetUploadLinkReturn = {
 | 
					export type GetUploadLinkReturn = {
 | 
				
			||||||
@@ -1171,6 +1189,11 @@ export enum InitPlaylistUploadStatusEnum {
 | 
				
			|||||||
  Uploaded = "UPLOADED",
 | 
					  Uploaded = "UPLOADED",
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type InitUploadAlreadyCompletedErr = {
 | 
				
			||||||
 | 
					  __typename?: "InitUploadAlreadyCompletedErr";
 | 
				
			||||||
 | 
					  segmentType: StreamSegmentTypeEnum;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type IntPoint2D = {
 | 
					export type IntPoint2D = {
 | 
				
			||||||
  __typename?: "IntPoint2D";
 | 
					  __typename?: "IntPoint2D";
 | 
				
			||||||
  x: Scalars["Int"]["output"];
 | 
					  x: Scalars["Int"]["output"];
 | 
				
			||||||
@@ -1189,12 +1212,14 @@ export type MustHaveSetForUploadLinkErr = {
 | 
				
			|||||||
  resolution?: Maybe<Scalars["Boolean"]["output"]>;
 | 
					  resolution?: Maybe<Scalars["Boolean"]["output"]>;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErr =
 | 
					export type MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr =
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    | InitUploadAlreadyCompletedErr
 | 
				
			||||||
    | MustHaveSetForUploadLinkErr
 | 
					    | MustHaveSetForUploadLinkErr
 | 
				
			||||||
    | NoInitForChunkedUploadErr
 | 
					    | NoInitForChunkedUploadErr
 | 
				
			||||||
    | ProcessingFailedErr
 | 
					    | ProcessingFailedErr
 | 
				
			||||||
    | SegmentAlreadyUploadedErr
 | 
					    | SegmentAlreadyUploadedErr
 | 
				
			||||||
 | 
					    | TooManyInitUploadsErr
 | 
				
			||||||
    | TooManyProfileImageUploadsErr;
 | 
					    | TooManyProfileImageUploadsErr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type Mutation = {
 | 
					export type Mutation = {
 | 
				
			||||||
@@ -1327,6 +1352,7 @@ export type Query = {
 | 
				
			|||||||
  getPlayTime: UserPlayTimeGql;
 | 
					  getPlayTime: UserPlayTimeGql;
 | 
				
			||||||
  getShotAnnotationTypes: Array<ShotAnnotationTypeGql>;
 | 
					  getShotAnnotationTypes: Array<ShotAnnotationTypeGql>;
 | 
				
			||||||
  getShots: Array<ShotGql>;
 | 
					  getShots: Array<ShotGql>;
 | 
				
			||||||
 | 
					  getShotsWithMetadata: GetShotsResult;
 | 
				
			||||||
  getUser?: Maybe<UserGql>;
 | 
					  getUser?: Maybe<UserGql>;
 | 
				
			||||||
  getUserTags: Array<TagGql>;
 | 
					  getUserTags: Array<TagGql>;
 | 
				
			||||||
  getUserVideos: VideoHistoryGql;
 | 
					  getUserVideos: VideoHistoryGql;
 | 
				
			||||||
@@ -1359,6 +1385,12 @@ export type QueryGetShotsArgs = {
 | 
				
			|||||||
  shotsPagination?: InputMaybe<GetShotsPagination>;
 | 
					  shotsPagination?: InputMaybe<GetShotsPagination>;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type QueryGetShotsWithMetadataArgs = {
 | 
				
			||||||
 | 
					  filterInput: FilterInput;
 | 
				
			||||||
 | 
					  limit?: Scalars["Int"]["input"];
 | 
				
			||||||
 | 
					  shotsPagination?: InputMaybe<GetShotsPagination>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type QueryGetUserArgs = {
 | 
					export type QueryGetUserArgs = {
 | 
				
			||||||
  userId: Scalars["Int"]["input"];
 | 
					  userId: Scalars["Int"]["input"];
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
@@ -1458,6 +1490,21 @@ export type ShotGql = {
 | 
				
			|||||||
  videoId: Scalars["Int"]["output"];
 | 
					  videoId: Scalars["Int"]["output"];
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type SpinTypeCountsGql = {
 | 
				
			||||||
 | 
					  __typename?: "SpinTypeCountsGQL";
 | 
				
			||||||
 | 
					  center: Scalars["Int"]["output"];
 | 
				
			||||||
 | 
					  draw: Scalars["Int"]["output"];
 | 
				
			||||||
 | 
					  follow: Scalars["Int"]["output"];
 | 
				
			||||||
 | 
					  unknown: Scalars["Int"]["output"];
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export enum SpinTypeEnum {
 | 
				
			||||||
 | 
					  Center = "CENTER",
 | 
				
			||||||
 | 
					  Draw = "DRAW",
 | 
				
			||||||
 | 
					  Follow = "FOLLOW",
 | 
				
			||||||
 | 
					  Unknown = "UNKNOWN",
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type StreamErrorGql = {
 | 
					export type StreamErrorGql = {
 | 
				
			||||||
  __typename?: "StreamErrorGQL";
 | 
					  __typename?: "StreamErrorGQL";
 | 
				
			||||||
  message: Scalars["String"]["output"];
 | 
					  message: Scalars["String"]["output"];
 | 
				
			||||||
@@ -1489,6 +1536,25 @@ export type TargetMetricsGql = {
 | 
				
			|||||||
  averageDifficulty?: Maybe<Scalars["Float"]["output"]>;
 | 
					  averageDifficulty?: Maybe<Scalars["Float"]["output"]>;
 | 
				
			||||||
  count: Scalars["Int"]["output"];
 | 
					  count: Scalars["Int"]["output"];
 | 
				
			||||||
  makePercentage?: Maybe<Scalars["Float"]["output"]>;
 | 
					  makePercentage?: Maybe<Scalars["Float"]["output"]>;
 | 
				
			||||||
 | 
					  spinTypeCounts?: Maybe<SpinTypeCountsGql>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type TimeInterval = {
 | 
				
			||||||
 | 
					  days?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  hours?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  minutes?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  /** Assumes a month is 30 days long */
 | 
				
			||||||
 | 
					  months?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  /** A second is the base unit and cannot be subdivided */
 | 
				
			||||||
 | 
					  seconds?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  weeks?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  /** Assumes a year is 365 days long */
 | 
				
			||||||
 | 
					  years?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type TooManyInitUploadsErr = {
 | 
				
			||||||
 | 
					  __typename?: "TooManyInitUploadsErr";
 | 
				
			||||||
 | 
					  linksRequested: Scalars["Int"]["output"];
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type TooManyProfileImageUploadsErr = {
 | 
					export type TooManyProfileImageUploadsErr = {
 | 
				
			||||||
@@ -1576,6 +1642,7 @@ export type VideoGql = {
 | 
				
			|||||||
  __typename?: "VideoGQL";
 | 
					  __typename?: "VideoGQL";
 | 
				
			||||||
  averageTimeBetweenShots?: Maybe<Scalars["Float"]["output"]>;
 | 
					  averageTimeBetweenShots?: Maybe<Scalars["Float"]["output"]>;
 | 
				
			||||||
  createdAt?: Maybe<Scalars["DateTime"]["output"]>;
 | 
					  createdAt?: Maybe<Scalars["DateTime"]["output"]>;
 | 
				
			||||||
 | 
					  currentHomography?: Maybe<HomographyInfoGql>;
 | 
				
			||||||
  currentProcessing?: Maybe<VideoProcessingGql>;
 | 
					  currentProcessing?: Maybe<VideoProcessingGql>;
 | 
				
			||||||
  elapsedTime?: Maybe<Scalars["Float"]["output"]>;
 | 
					  elapsedTime?: Maybe<Scalars["Float"]["output"]>;
 | 
				
			||||||
  endTime?: Maybe<Scalars["DateTime"]["output"]>;
 | 
					  endTime?: Maybe<Scalars["DateTime"]["output"]>;
 | 
				
			||||||
@@ -1777,6 +1844,7 @@ export type GetShotsQueryVariables = Exact<{
 | 
				
			|||||||
  includeCueObjectDistance?: Scalars["Boolean"]["input"];
 | 
					  includeCueObjectDistance?: Scalars["Boolean"]["input"];
 | 
				
			||||||
  includeCueObjectAngle?: Scalars["Boolean"]["input"];
 | 
					  includeCueObjectAngle?: Scalars["Boolean"]["input"];
 | 
				
			||||||
  includeCueBallSpeed?: Scalars["Boolean"]["input"];
 | 
					  includeCueBallSpeed?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeSpinType?: Scalars["Boolean"]["input"];
 | 
				
			||||||
  includeShotDirection?: Scalars["Boolean"]["input"];
 | 
					  includeShotDirection?: Scalars["Boolean"]["input"];
 | 
				
			||||||
  includeTargetPocketDistance?: Scalars["Boolean"]["input"];
 | 
					  includeTargetPocketDistance?: Scalars["Boolean"]["input"];
 | 
				
			||||||
  includeMake?: Scalars["Boolean"]["input"];
 | 
					  includeMake?: Scalars["Boolean"]["input"];
 | 
				
			||||||
@@ -1795,12 +1863,24 @@ export type GetShotsQuery = {
 | 
				
			|||||||
    createdAt?: any | null;
 | 
					    createdAt?: any | null;
 | 
				
			||||||
    updatedAt?: any | null;
 | 
					    updatedAt?: any | null;
 | 
				
			||||||
    user?: { __typename?: "UserGQL"; id: number } | null;
 | 
					    user?: { __typename?: "UserGQL"; id: number } | null;
 | 
				
			||||||
 | 
					    video?: {
 | 
				
			||||||
 | 
					      __typename?: "VideoGQL";
 | 
				
			||||||
 | 
					      stream?: {
 | 
				
			||||||
 | 
					        __typename?: "UploadStreamGQL";
 | 
				
			||||||
 | 
					        resolution: {
 | 
				
			||||||
 | 
					          __typename?: "VideoResolutionGQL";
 | 
				
			||||||
 | 
					          width?: number | null;
 | 
				
			||||||
 | 
					          height?: number | null;
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					      } | null;
 | 
				
			||||||
 | 
					    } | null;
 | 
				
			||||||
    cueObjectFeatures?: {
 | 
					    cueObjectFeatures?: {
 | 
				
			||||||
      __typename?: "CueObjectFeaturesGQL";
 | 
					      __typename?: "CueObjectFeaturesGQL";
 | 
				
			||||||
      cueObjectDistance?: number | null;
 | 
					      cueObjectDistance?: number | null;
 | 
				
			||||||
      cueObjectAngle?: number | null;
 | 
					      cueObjectAngle?: number | null;
 | 
				
			||||||
      cueBallSpeed?: number | null;
 | 
					      cueBallSpeed?: number | null;
 | 
				
			||||||
      shotDirection?: ShotDirectionEnum | null;
 | 
					      shotDirection?: ShotDirectionEnum | null;
 | 
				
			||||||
 | 
					      spinType?: SpinTypeEnum | null;
 | 
				
			||||||
    } | null;
 | 
					    } | null;
 | 
				
			||||||
    pocketingIntentionFeatures?: {
 | 
					    pocketingIntentionFeatures?: {
 | 
				
			||||||
      __typename?: "PocketingIntentionFeaturesGQL";
 | 
					      __typename?: "PocketingIntentionFeaturesGQL";
 | 
				
			||||||
@@ -1811,6 +1891,25 @@ export type GetShotsQuery = {
 | 
				
			|||||||
  }>;
 | 
					  }>;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetSerializedShotPathsQueryVariables = Exact<{
 | 
				
			||||||
 | 
					  filterInput: FilterInput;
 | 
				
			||||||
 | 
					}>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetSerializedShotPathsQuery = {
 | 
				
			||||||
 | 
					  __typename?: "Query";
 | 
				
			||||||
 | 
					  getShots: Array<{
 | 
				
			||||||
 | 
					    __typename?: "ShotGQL";
 | 
				
			||||||
 | 
					    id: number;
 | 
				
			||||||
 | 
					    videoId: number;
 | 
				
			||||||
 | 
					    startFrame: number;
 | 
				
			||||||
 | 
					    endFrame: number;
 | 
				
			||||||
 | 
					    serializedShotPaths?: {
 | 
				
			||||||
 | 
					      __typename?: "SerializedShotPathsGQL";
 | 
				
			||||||
 | 
					      b64EncodedBuffer?: string | null;
 | 
				
			||||||
 | 
					    } | null;
 | 
				
			||||||
 | 
					  }>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type GetShotAnnotationTypesQueryVariables = Exact<{
 | 
					export type GetShotAnnotationTypesQueryVariables = Exact<{
 | 
				
			||||||
  [key: string]: never;
 | 
					  [key: string]: never;
 | 
				
			||||||
}>;
 | 
					}>;
 | 
				
			||||||
@@ -1824,6 +1923,72 @@ export type GetShotAnnotationTypesQuery = {
 | 
				
			|||||||
  }>;
 | 
					  }>;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetShotsWithMetadataQueryVariables = Exact<{
 | 
				
			||||||
 | 
					  filterInput: FilterInput;
 | 
				
			||||||
 | 
					  shotsPagination?: InputMaybe<GetShotsPagination>;
 | 
				
			||||||
 | 
					  limit?: InputMaybe<Scalars["Int"]["input"]>;
 | 
				
			||||||
 | 
					  includeCreatedAt?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeUpdatedAt?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeCueObjectFeatures?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includePocketingIntentionFeatures?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeCueObjectDistance?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeCueObjectAngle?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeCueBallSpeed?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeSpinType?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeShotDirection?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeTargetPocketDistance?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeMake?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					  includeIntendedPocketType?: Scalars["Boolean"]["input"];
 | 
				
			||||||
 | 
					}>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetShotsWithMetadataQuery = {
 | 
				
			||||||
 | 
					  __typename?: "Query";
 | 
				
			||||||
 | 
					  getShotsWithMetadata: {
 | 
				
			||||||
 | 
					    __typename?: "GetShotsResult";
 | 
				
			||||||
 | 
					    count?: number | null;
 | 
				
			||||||
 | 
					    shots: Array<{
 | 
				
			||||||
 | 
					      __typename?: "ShotGQL";
 | 
				
			||||||
 | 
					      id: number;
 | 
				
			||||||
 | 
					      videoId: number;
 | 
				
			||||||
 | 
					      startFrame: number;
 | 
				
			||||||
 | 
					      endFrame: number;
 | 
				
			||||||
 | 
					      falsePositiveScore?: number | null;
 | 
				
			||||||
 | 
					      createdAt?: any | null;
 | 
				
			||||||
 | 
					      updatedAt?: any | null;
 | 
				
			||||||
 | 
					      user?: { __typename?: "UserGQL"; id: number } | null;
 | 
				
			||||||
 | 
					      video?: {
 | 
				
			||||||
 | 
					        __typename?: "VideoGQL";
 | 
				
			||||||
 | 
					        stream?: {
 | 
				
			||||||
 | 
					          __typename?: "UploadStreamGQL";
 | 
				
			||||||
 | 
					          resolution: {
 | 
				
			||||||
 | 
					            __typename?: "VideoResolutionGQL";
 | 
				
			||||||
 | 
					            width?: number | null;
 | 
				
			||||||
 | 
					            height?: number | null;
 | 
				
			||||||
 | 
					          };
 | 
				
			||||||
 | 
					        } | null;
 | 
				
			||||||
 | 
					      } | null;
 | 
				
			||||||
 | 
					      serializedShotPaths?: {
 | 
				
			||||||
 | 
					        __typename?: "SerializedShotPathsGQL";
 | 
				
			||||||
 | 
					        b64EncodedBuffer?: string | null;
 | 
				
			||||||
 | 
					      } | null;
 | 
				
			||||||
 | 
					      cueObjectFeatures?: {
 | 
				
			||||||
 | 
					        __typename?: "CueObjectFeaturesGQL";
 | 
				
			||||||
 | 
					        cueObjectDistance?: number | null;
 | 
				
			||||||
 | 
					        cueObjectAngle?: number | null;
 | 
				
			||||||
 | 
					        cueBallSpeed?: number | null;
 | 
				
			||||||
 | 
					        shotDirection?: ShotDirectionEnum | null;
 | 
				
			||||||
 | 
					        spinType?: SpinTypeEnum | null;
 | 
				
			||||||
 | 
					      } | null;
 | 
				
			||||||
 | 
					      pocketingIntentionFeatures?: {
 | 
				
			||||||
 | 
					        __typename?: "PocketingIntentionFeaturesGQL";
 | 
				
			||||||
 | 
					        targetPocketDistance?: number | null;
 | 
				
			||||||
 | 
					        make?: boolean | null;
 | 
				
			||||||
 | 
					        intendedPocketType?: PocketEnum | null;
 | 
				
			||||||
 | 
					      } | null;
 | 
				
			||||||
 | 
					    }>;
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type GetProfileImageUploadLinkMutationVariables = Exact<{
 | 
					export type GetProfileImageUploadLinkMutationVariables = Exact<{
 | 
				
			||||||
  fileExt?: InputMaybe<Scalars["String"]["input"]>;
 | 
					  fileExt?: InputMaybe<Scalars["String"]["input"]>;
 | 
				
			||||||
}>;
 | 
					}>;
 | 
				
			||||||
@@ -1906,6 +2071,13 @@ export type GetUsernamesQuery = {
 | 
				
			|||||||
  getUsernames: Array<string>;
 | 
					  getUsernames: Array<string>;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetUserTagsQueryVariables = Exact<{ [key: string]: never }>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export type GetUserTagsQuery = {
 | 
				
			||||||
 | 
					  __typename?: "Query";
 | 
				
			||||||
 | 
					  getUserTags: Array<{ __typename?: "TagGQL"; id: number; name: string }>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type GetStreamMonitoringDetailsQueryVariables = Exact<{
 | 
					export type GetStreamMonitoringDetailsQueryVariables = Exact<{
 | 
				
			||||||
  videoId: Scalars["Int"]["input"];
 | 
					  videoId: Scalars["Int"]["input"];
 | 
				
			||||||
  debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>;
 | 
					  debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>;
 | 
				
			||||||
@@ -1919,7 +2091,7 @@ export type GetStreamMonitoringDetailsQuery = {
 | 
				
			|||||||
    totalShots: number;
 | 
					    totalShots: number;
 | 
				
			||||||
    makePercentage: number;
 | 
					    makePercentage: number;
 | 
				
			||||||
    elapsedTime?: number | null;
 | 
					    elapsedTime?: number | null;
 | 
				
			||||||
    homographyHistory: Array<{
 | 
					    currentHomography?: {
 | 
				
			||||||
      __typename?: "HomographyInfoGQL";
 | 
					      __typename?: "HomographyInfoGQL";
 | 
				
			||||||
      crop: {
 | 
					      crop: {
 | 
				
			||||||
        __typename?: "BoundingBoxGQL";
 | 
					        __typename?: "BoundingBoxGQL";
 | 
				
			||||||
@@ -1944,7 +2116,7 @@ export type GetStreamMonitoringDetailsQuery = {
 | 
				
			|||||||
        bottomSide: { __typename?: "IntPoint2D"; x: number; y: number };
 | 
					        bottomSide: { __typename?: "IntPoint2D"; x: number; y: number };
 | 
				
			||||||
        bottomRight: { __typename?: "IntPoint2D"; x: number; y: number };
 | 
					        bottomRight: { __typename?: "IntPoint2D"; x: number; y: number };
 | 
				
			||||||
      };
 | 
					      };
 | 
				
			||||||
    }>;
 | 
					    } | null;
 | 
				
			||||||
    stream?: {
 | 
					    stream?: {
 | 
				
			||||||
      __typename?: "UploadStreamGQL";
 | 
					      __typename?: "UploadStreamGQL";
 | 
				
			||||||
      linksRequested: number;
 | 
					      linksRequested: number;
 | 
				
			||||||
@@ -2044,13 +2216,11 @@ export type GetVideosQuery = {
 | 
				
			|||||||
  getVideos: Array<{
 | 
					  getVideos: Array<{
 | 
				
			||||||
    __typename?: "VideoGQL";
 | 
					    __typename?: "VideoGQL";
 | 
				
			||||||
    id: number;
 | 
					    id: number;
 | 
				
			||||||
    playlist?: {
 | 
					    framesPerSecond: number;
 | 
				
			||||||
      __typename?: "HLSPlaylistGQL";
 | 
					 | 
				
			||||||
      segmentDurations: Array<number>;
 | 
					 | 
				
			||||||
    } | null;
 | 
					 | 
				
			||||||
    stream?: {
 | 
					    stream?: {
 | 
				
			||||||
      __typename?: "UploadStreamGQL";
 | 
					      __typename?: "UploadStreamGQL";
 | 
				
			||||||
      id: string;
 | 
					      id: string;
 | 
				
			||||||
 | 
					      streamSegmentType: StreamSegmentTypeEnum;
 | 
				
			||||||
      segments: Array<{
 | 
					      segments: Array<{
 | 
				
			||||||
        __typename?: "UploadSegmentGQL";
 | 
					        __typename?: "UploadSegmentGQL";
 | 
				
			||||||
        uploaded: boolean;
 | 
					        uploaded: boolean;
 | 
				
			||||||
@@ -2060,6 +2230,10 @@ export type GetVideosQuery = {
 | 
				
			|||||||
        framesPerSecond?: number | null;
 | 
					        framesPerSecond?: number | null;
 | 
				
			||||||
      }>;
 | 
					      }>;
 | 
				
			||||||
    } | null;
 | 
					    } | null;
 | 
				
			||||||
 | 
					    playlist?: {
 | 
				
			||||||
 | 
					      __typename?: "HLSPlaylistGQL";
 | 
				
			||||||
 | 
					      segmentDurations: Array<number>;
 | 
				
			||||||
 | 
					    } | null;
 | 
				
			||||||
  }>;
 | 
					  }>;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2211,6 +2385,7 @@ export type GetUploadLinkMutation = {
 | 
				
			|||||||
      | {
 | 
					      | {
 | 
				
			||||||
          __typename?: "GetUploadLinkErrors";
 | 
					          __typename?: "GetUploadLinkErrors";
 | 
				
			||||||
          error:
 | 
					          error:
 | 
				
			||||||
 | 
					            | { __typename?: "InitUploadAlreadyCompletedErr" }
 | 
				
			||||||
            | {
 | 
					            | {
 | 
				
			||||||
                __typename?: "MustHaveSetForUploadLinkErr";
 | 
					                __typename?: "MustHaveSetForUploadLinkErr";
 | 
				
			||||||
                resolution?: boolean | null;
 | 
					                resolution?: boolean | null;
 | 
				
			||||||
@@ -2229,6 +2404,7 @@ export type GetUploadLinkMutation = {
 | 
				
			|||||||
                };
 | 
					                };
 | 
				
			||||||
              }
 | 
					              }
 | 
				
			||||||
            | { __typename?: "SegmentAlreadyUploadedErr"; segmentId: number }
 | 
					            | { __typename?: "SegmentAlreadyUploadedErr"; segmentId: number }
 | 
				
			||||||
 | 
					            | { __typename?: "TooManyInitUploadsErr" }
 | 
				
			||||||
            | { __typename?: "TooManyProfileImageUploadsErr" };
 | 
					            | { __typename?: "TooManyProfileImageUploadsErr" };
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      | {
 | 
					      | {
 | 
				
			||||||
@@ -2259,6 +2435,10 @@ export type GetHlsInitUploadLinkMutation = {
 | 
				
			|||||||
      | {
 | 
					      | {
 | 
				
			||||||
          __typename?: "GetUploadLinkErrors";
 | 
					          __typename?: "GetUploadLinkErrors";
 | 
				
			||||||
          error:
 | 
					          error:
 | 
				
			||||||
 | 
					            | {
 | 
				
			||||||
 | 
					                __typename?: "InitUploadAlreadyCompletedErr";
 | 
				
			||||||
 | 
					                segmentType: StreamSegmentTypeEnum;
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
            | { __typename?: "MustHaveSetForUploadLinkErr" }
 | 
					            | { __typename?: "MustHaveSetForUploadLinkErr" }
 | 
				
			||||||
            | {
 | 
					            | {
 | 
				
			||||||
                __typename?: "NoInitForChunkedUploadErr";
 | 
					                __typename?: "NoInitForChunkedUploadErr";
 | 
				
			||||||
@@ -2266,6 +2446,7 @@ export type GetHlsInitUploadLinkMutation = {
 | 
				
			|||||||
              }
 | 
					              }
 | 
				
			||||||
            | { __typename?: "ProcessingFailedErr" }
 | 
					            | { __typename?: "ProcessingFailedErr" }
 | 
				
			||||||
            | { __typename?: "SegmentAlreadyUploadedErr" }
 | 
					            | { __typename?: "SegmentAlreadyUploadedErr" }
 | 
				
			||||||
 | 
					            | { __typename?: "TooManyInitUploadsErr"; linksRequested: number }
 | 
				
			||||||
            | { __typename?: "TooManyProfileImageUploadsErr" };
 | 
					            | { __typename?: "TooManyProfileImageUploadsErr" };
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      | {
 | 
					      | {
 | 
				
			||||||
@@ -2702,6 +2883,7 @@ export const GetShotsDocument = gql`
 | 
				
			|||||||
    $includeCueObjectDistance: Boolean! = false
 | 
					    $includeCueObjectDistance: Boolean! = false
 | 
				
			||||||
    $includeCueObjectAngle: Boolean! = false
 | 
					    $includeCueObjectAngle: Boolean! = false
 | 
				
			||||||
    $includeCueBallSpeed: Boolean! = false
 | 
					    $includeCueBallSpeed: Boolean! = false
 | 
				
			||||||
 | 
					    $includeSpinType: Boolean! = false
 | 
				
			||||||
    $includeShotDirection: Boolean! = false
 | 
					    $includeShotDirection: Boolean! = false
 | 
				
			||||||
    $includeTargetPocketDistance: Boolean! = false
 | 
					    $includeTargetPocketDistance: Boolean! = false
 | 
				
			||||||
    $includeMake: Boolean! = false
 | 
					    $includeMake: Boolean! = false
 | 
				
			||||||
@@ -2720,6 +2902,14 @@ export const GetShotsDocument = gql`
 | 
				
			|||||||
        id
 | 
					        id
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      falsePositiveScore
 | 
					      falsePositiveScore
 | 
				
			||||||
 | 
					      video {
 | 
				
			||||||
 | 
					        stream {
 | 
				
			||||||
 | 
					          resolution {
 | 
				
			||||||
 | 
					            width
 | 
				
			||||||
 | 
					            height
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
      createdAt @include(if: $includeCreatedAt)
 | 
					      createdAt @include(if: $includeCreatedAt)
 | 
				
			||||||
      updatedAt @include(if: $includeUpdatedAt)
 | 
					      updatedAt @include(if: $includeUpdatedAt)
 | 
				
			||||||
      cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
					      cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
				
			||||||
@@ -2727,6 +2917,7 @@ export const GetShotsDocument = gql`
 | 
				
			|||||||
        cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
					        cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
				
			||||||
        cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
					        cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
				
			||||||
        shotDirection @include(if: $includeShotDirection)
 | 
					        shotDirection @include(if: $includeShotDirection)
 | 
				
			||||||
 | 
					        spinType @include(if: $includeSpinType)
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      pocketingIntentionFeatures
 | 
					      pocketingIntentionFeatures
 | 
				
			||||||
        @include(if: $includePocketingIntentionFeatures) {
 | 
					        @include(if: $includePocketingIntentionFeatures) {
 | 
				
			||||||
@@ -2760,6 +2951,7 @@ export const GetShotsDocument = gql`
 | 
				
			|||||||
 *      includeCueObjectDistance: // value for 'includeCueObjectDistance'
 | 
					 *      includeCueObjectDistance: // value for 'includeCueObjectDistance'
 | 
				
			||||||
 *      includeCueObjectAngle: // value for 'includeCueObjectAngle'
 | 
					 *      includeCueObjectAngle: // value for 'includeCueObjectAngle'
 | 
				
			||||||
 *      includeCueBallSpeed: // value for 'includeCueBallSpeed'
 | 
					 *      includeCueBallSpeed: // value for 'includeCueBallSpeed'
 | 
				
			||||||
 | 
					 *      includeSpinType: // value for 'includeSpinType'
 | 
				
			||||||
 *      includeShotDirection: // value for 'includeShotDirection'
 | 
					 *      includeShotDirection: // value for 'includeShotDirection'
 | 
				
			||||||
 *      includeTargetPocketDistance: // value for 'includeTargetPocketDistance'
 | 
					 *      includeTargetPocketDistance: // value for 'includeTargetPocketDistance'
 | 
				
			||||||
 *      includeMake: // value for 'includeMake'
 | 
					 *      includeMake: // value for 'includeMake'
 | 
				
			||||||
@@ -2811,6 +3003,85 @@ export type GetShotsQueryResult = Apollo.QueryResult<
 | 
				
			|||||||
  GetShotsQuery,
 | 
					  GetShotsQuery,
 | 
				
			||||||
  GetShotsQueryVariables
 | 
					  GetShotsQueryVariables
 | 
				
			||||||
>;
 | 
					>;
 | 
				
			||||||
 | 
					export const GetSerializedShotPathsDocument = gql`
 | 
				
			||||||
 | 
					  query GetSerializedShotPaths($filterInput: FilterInput!) {
 | 
				
			||||||
 | 
					    getShots(filterInput: $filterInput) {
 | 
				
			||||||
 | 
					      id
 | 
				
			||||||
 | 
					      videoId
 | 
				
			||||||
 | 
					      startFrame
 | 
				
			||||||
 | 
					      endFrame
 | 
				
			||||||
 | 
					      serializedShotPaths {
 | 
				
			||||||
 | 
					        b64EncodedBuffer
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					`;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * __useGetSerializedShotPathsQuery__
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * To run a query within a React component, call `useGetSerializedShotPathsQuery` and pass it any options that fit your needs.
 | 
				
			||||||
 | 
					 * When your component renders, `useGetSerializedShotPathsQuery` returns an object from Apollo Client that contains loading, error, and data properties
 | 
				
			||||||
 | 
					 * you can use to render your UI.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options;
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @example
 | 
				
			||||||
 | 
					 * const { data, loading, error } = useGetSerializedShotPathsQuery({
 | 
				
			||||||
 | 
					 *   variables: {
 | 
				
			||||||
 | 
					 *      filterInput: // value for 'filterInput'
 | 
				
			||||||
 | 
					 *   },
 | 
				
			||||||
 | 
					 * });
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export function useGetSerializedShotPathsQuery(
 | 
				
			||||||
 | 
					  baseOptions: Apollo.QueryHookOptions<
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useQuery<
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					  >(GetSerializedShotPathsDocument, options);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export function useGetSerializedShotPathsLazyQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.LazyQueryHookOptions<
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useLazyQuery<
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					  >(GetSerializedShotPathsDocument, options);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export function useGetSerializedShotPathsSuspenseQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.SuspenseQueryHookOptions<
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useSuspenseQuery<
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					    GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					  >(GetSerializedShotPathsDocument, options);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export type GetSerializedShotPathsQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetSerializedShotPathsQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetSerializedShotPathsLazyQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetSerializedShotPathsLazyQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetSerializedShotPathsSuspenseQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetSerializedShotPathsSuspenseQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetSerializedShotPathsQueryResult = Apollo.QueryResult<
 | 
				
			||||||
 | 
					  GetSerializedShotPathsQuery,
 | 
				
			||||||
 | 
					  GetSerializedShotPathsQueryVariables
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
export const GetShotAnnotationTypesDocument = gql`
 | 
					export const GetShotAnnotationTypesDocument = gql`
 | 
				
			||||||
  query GetShotAnnotationTypes {
 | 
					  query GetShotAnnotationTypes {
 | 
				
			||||||
    getShotAnnotationTypes {
 | 
					    getShotAnnotationTypes {
 | 
				
			||||||
@@ -2884,6 +3155,149 @@ export type GetShotAnnotationTypesQueryResult = Apollo.QueryResult<
 | 
				
			|||||||
  GetShotAnnotationTypesQuery,
 | 
					  GetShotAnnotationTypesQuery,
 | 
				
			||||||
  GetShotAnnotationTypesQueryVariables
 | 
					  GetShotAnnotationTypesQueryVariables
 | 
				
			||||||
>;
 | 
					>;
 | 
				
			||||||
 | 
					export const GetShotsWithMetadataDocument = gql`
 | 
				
			||||||
 | 
					  query GetShotsWithMetadata(
 | 
				
			||||||
 | 
					    $filterInput: FilterInput!
 | 
				
			||||||
 | 
					    $shotsPagination: GetShotsPagination
 | 
				
			||||||
 | 
					    $limit: Int
 | 
				
			||||||
 | 
					    $includeCreatedAt: Boolean! = false
 | 
				
			||||||
 | 
					    $includeUpdatedAt: Boolean! = false
 | 
				
			||||||
 | 
					    $includeCueObjectFeatures: Boolean! = false
 | 
				
			||||||
 | 
					    $includePocketingIntentionFeatures: Boolean! = false
 | 
				
			||||||
 | 
					    $includeCueObjectDistance: Boolean! = false
 | 
				
			||||||
 | 
					    $includeCueObjectAngle: Boolean! = false
 | 
				
			||||||
 | 
					    $includeCueBallSpeed: Boolean! = false
 | 
				
			||||||
 | 
					    $includeSpinType: Boolean! = false
 | 
				
			||||||
 | 
					    $includeShotDirection: Boolean! = false
 | 
				
			||||||
 | 
					    $includeTargetPocketDistance: Boolean! = false
 | 
				
			||||||
 | 
					    $includeMake: Boolean! = false
 | 
				
			||||||
 | 
					    $includeIntendedPocketType: Boolean! = false
 | 
				
			||||||
 | 
					  ) {
 | 
				
			||||||
 | 
					    getShotsWithMetadata(
 | 
				
			||||||
 | 
					      filterInput: $filterInput
 | 
				
			||||||
 | 
					      shotsPagination: $shotsPagination
 | 
				
			||||||
 | 
					      limit: $limit
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
 | 
					      count
 | 
				
			||||||
 | 
					      shots {
 | 
				
			||||||
 | 
					        id
 | 
				
			||||||
 | 
					        videoId
 | 
				
			||||||
 | 
					        startFrame
 | 
				
			||||||
 | 
					        endFrame
 | 
				
			||||||
 | 
					        user {
 | 
				
			||||||
 | 
					          id
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        falsePositiveScore
 | 
				
			||||||
 | 
					        video {
 | 
				
			||||||
 | 
					          stream {
 | 
				
			||||||
 | 
					            resolution {
 | 
				
			||||||
 | 
					              width
 | 
				
			||||||
 | 
					              height
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        serializedShotPaths {
 | 
				
			||||||
 | 
					          b64EncodedBuffer
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        createdAt @include(if: $includeCreatedAt)
 | 
				
			||||||
 | 
					        updatedAt @include(if: $includeUpdatedAt)
 | 
				
			||||||
 | 
					        cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
				
			||||||
 | 
					          cueObjectDistance @include(if: $includeCueObjectDistance)
 | 
				
			||||||
 | 
					          cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
				
			||||||
 | 
					          cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
				
			||||||
 | 
					          shotDirection @include(if: $includeShotDirection)
 | 
				
			||||||
 | 
					          spinType @include(if: $includeSpinType)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        pocketingIntentionFeatures
 | 
				
			||||||
 | 
					          @include(if: $includePocketingIntentionFeatures) {
 | 
				
			||||||
 | 
					          targetPocketDistance @include(if: $includeTargetPocketDistance)
 | 
				
			||||||
 | 
					          make @include(if: $includeMake)
 | 
				
			||||||
 | 
					          intendedPocketType @include(if: $includeIntendedPocketType)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					`;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * __useGetShotsWithMetadataQuery__
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * To run a query within a React component, call `useGetShotsWithMetadataQuery` and pass it any options that fit your needs.
 | 
				
			||||||
 | 
					 * When your component renders, `useGetShotsWithMetadataQuery` returns an object from Apollo Client that contains loading, error, and data properties
 | 
				
			||||||
 | 
					 * you can use to render your UI.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options;
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @example
 | 
				
			||||||
 | 
					 * const { data, loading, error } = useGetShotsWithMetadataQuery({
 | 
				
			||||||
 | 
					 *   variables: {
 | 
				
			||||||
 | 
					 *      filterInput: // value for 'filterInput'
 | 
				
			||||||
 | 
					 *      shotsPagination: // value for 'shotsPagination'
 | 
				
			||||||
 | 
					 *      limit: // value for 'limit'
 | 
				
			||||||
 | 
					 *      includeCreatedAt: // value for 'includeCreatedAt'
 | 
				
			||||||
 | 
					 *      includeUpdatedAt: // value for 'includeUpdatedAt'
 | 
				
			||||||
 | 
					 *      includeCueObjectFeatures: // value for 'includeCueObjectFeatures'
 | 
				
			||||||
 | 
					 *      includePocketingIntentionFeatures: // value for 'includePocketingIntentionFeatures'
 | 
				
			||||||
 | 
					 *      includeCueObjectDistance: // value for 'includeCueObjectDistance'
 | 
				
			||||||
 | 
					 *      includeCueObjectAngle: // value for 'includeCueObjectAngle'
 | 
				
			||||||
 | 
					 *      includeCueBallSpeed: // value for 'includeCueBallSpeed'
 | 
				
			||||||
 | 
					 *      includeSpinType: // value for 'includeSpinType'
 | 
				
			||||||
 | 
					 *      includeShotDirection: // value for 'includeShotDirection'
 | 
				
			||||||
 | 
					 *      includeTargetPocketDistance: // value for 'includeTargetPocketDistance'
 | 
				
			||||||
 | 
					 *      includeMake: // value for 'includeMake'
 | 
				
			||||||
 | 
					 *      includeIntendedPocketType: // value for 'includeIntendedPocketType'
 | 
				
			||||||
 | 
					 *   },
 | 
				
			||||||
 | 
					 * });
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export function useGetShotsWithMetadataQuery(
 | 
				
			||||||
 | 
					  baseOptions: Apollo.QueryHookOptions<
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useQuery<
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					  >(GetShotsWithMetadataDocument, options);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export function useGetShotsWithMetadataLazyQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.LazyQueryHookOptions<
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useLazyQuery<
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					  >(GetShotsWithMetadataDocument, options);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export function useGetShotsWithMetadataSuspenseQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.SuspenseQueryHookOptions<
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useSuspenseQuery<
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					    GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					  >(GetShotsWithMetadataDocument, options);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export type GetShotsWithMetadataQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetShotsWithMetadataQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetShotsWithMetadataLazyQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetShotsWithMetadataLazyQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetShotsWithMetadataSuspenseQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetShotsWithMetadataSuspenseQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetShotsWithMetadataQueryResult = Apollo.QueryResult<
 | 
				
			||||||
 | 
					  GetShotsWithMetadataQuery,
 | 
				
			||||||
 | 
					  GetShotsWithMetadataQueryVariables
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
export const GetProfileImageUploadLinkDocument = gql`
 | 
					export const GetProfileImageUploadLinkDocument = gql`
 | 
				
			||||||
  mutation getProfileImageUploadLink($fileExt: String = ".png") {
 | 
					  mutation getProfileImageUploadLink($fileExt: String = ".png") {
 | 
				
			||||||
    getProfileImageUploadLink(fileExt: $fileExt) {
 | 
					    getProfileImageUploadLink(fileExt: $fileExt) {
 | 
				
			||||||
@@ -3234,6 +3648,77 @@ export type GetUsernamesQueryResult = Apollo.QueryResult<
 | 
				
			|||||||
  GetUsernamesQuery,
 | 
					  GetUsernamesQuery,
 | 
				
			||||||
  GetUsernamesQueryVariables
 | 
					  GetUsernamesQueryVariables
 | 
				
			||||||
>;
 | 
					>;
 | 
				
			||||||
 | 
					export const GetUserTagsDocument = gql`
 | 
				
			||||||
 | 
					  query GetUserTags {
 | 
				
			||||||
 | 
					    getUserTags {
 | 
				
			||||||
 | 
					      id
 | 
				
			||||||
 | 
					      name
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					`;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * __useGetUserTagsQuery__
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * To run a query within a React component, call `useGetUserTagsQuery` and pass it any options that fit your needs.
 | 
				
			||||||
 | 
					 * When your component renders, `useGetUserTagsQuery` returns an object from Apollo Client that contains loading, error, and data properties
 | 
				
			||||||
 | 
					 * you can use to render your UI.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options;
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @example
 | 
				
			||||||
 | 
					 * const { data, loading, error } = useGetUserTagsQuery({
 | 
				
			||||||
 | 
					 *   variables: {
 | 
				
			||||||
 | 
					 *   },
 | 
				
			||||||
 | 
					 * });
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export function useGetUserTagsQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.QueryHookOptions<
 | 
				
			||||||
 | 
					    GetUserTagsQuery,
 | 
				
			||||||
 | 
					    GetUserTagsQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useQuery<GetUserTagsQuery, GetUserTagsQueryVariables>(
 | 
				
			||||||
 | 
					    GetUserTagsDocument,
 | 
				
			||||||
 | 
					    options,
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export function useGetUserTagsLazyQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.LazyQueryHookOptions<
 | 
				
			||||||
 | 
					    GetUserTagsQuery,
 | 
				
			||||||
 | 
					    GetUserTagsQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useLazyQuery<GetUserTagsQuery, GetUserTagsQueryVariables>(
 | 
				
			||||||
 | 
					    GetUserTagsDocument,
 | 
				
			||||||
 | 
					    options,
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export function useGetUserTagsSuspenseQuery(
 | 
				
			||||||
 | 
					  baseOptions?: Apollo.SuspenseQueryHookOptions<
 | 
				
			||||||
 | 
					    GetUserTagsQuery,
 | 
				
			||||||
 | 
					    GetUserTagsQueryVariables
 | 
				
			||||||
 | 
					  >,
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  const options = { ...defaultOptions, ...baseOptions };
 | 
				
			||||||
 | 
					  return Apollo.useSuspenseQuery<GetUserTagsQuery, GetUserTagsQueryVariables>(
 | 
				
			||||||
 | 
					    GetUserTagsDocument,
 | 
				
			||||||
 | 
					    options,
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export type GetUserTagsQueryHookResult = ReturnType<typeof useGetUserTagsQuery>;
 | 
				
			||||||
 | 
					export type GetUserTagsLazyQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetUserTagsLazyQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetUserTagsSuspenseQueryHookResult = ReturnType<
 | 
				
			||||||
 | 
					  typeof useGetUserTagsSuspenseQuery
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
 | 
					export type GetUserTagsQueryResult = Apollo.QueryResult<
 | 
				
			||||||
 | 
					  GetUserTagsQuery,
 | 
				
			||||||
 | 
					  GetUserTagsQueryVariables
 | 
				
			||||||
 | 
					>;
 | 
				
			||||||
export const GetStreamMonitoringDetailsDocument = gql`
 | 
					export const GetStreamMonitoringDetailsDocument = gql`
 | 
				
			||||||
  query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) {
 | 
					  query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) {
 | 
				
			||||||
    getVideo(videoId: $videoId, debuggingJson: $debuggingJson) {
 | 
					    getVideo(videoId: $videoId, debuggingJson: $debuggingJson) {
 | 
				
			||||||
@@ -3241,7 +3726,7 @@ export const GetStreamMonitoringDetailsDocument = gql`
 | 
				
			|||||||
      totalShots
 | 
					      totalShots
 | 
				
			||||||
      makePercentage
 | 
					      makePercentage
 | 
				
			||||||
      elapsedTime
 | 
					      elapsedTime
 | 
				
			||||||
      homographyHistory {
 | 
					      currentHomography {
 | 
				
			||||||
        crop {
 | 
					        crop {
 | 
				
			||||||
          left
 | 
					          left
 | 
				
			||||||
          top
 | 
					          top
 | 
				
			||||||
@@ -3601,11 +4086,10 @@ export const GetVideosDocument = gql`
 | 
				
			|||||||
  query GetVideos($videoIds: [Int!]!) {
 | 
					  query GetVideos($videoIds: [Int!]!) {
 | 
				
			||||||
    getVideos(videoIds: $videoIds) {
 | 
					    getVideos(videoIds: $videoIds) {
 | 
				
			||||||
      id
 | 
					      id
 | 
				
			||||||
      playlist {
 | 
					      framesPerSecond
 | 
				
			||||||
        segmentDurations
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      stream {
 | 
					      stream {
 | 
				
			||||||
        id
 | 
					        id
 | 
				
			||||||
 | 
					        streamSegmentType
 | 
				
			||||||
        segments {
 | 
					        segments {
 | 
				
			||||||
          uploaded
 | 
					          uploaded
 | 
				
			||||||
          valid
 | 
					          valid
 | 
				
			||||||
@@ -3614,6 +4098,9 @@ export const GetVideosDocument = gql`
 | 
				
			|||||||
          framesPerSecond
 | 
					          framesPerSecond
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      playlist {
 | 
				
			||||||
 | 
					        segmentDurations
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
`;
 | 
					`;
 | 
				
			||||||
@@ -4259,6 +4746,12 @@ export const GetHlsInitUploadLinkDocument = gql`
 | 
				
			|||||||
            ... on NoInitForChunkedUploadErr {
 | 
					            ... on NoInitForChunkedUploadErr {
 | 
				
			||||||
              segmentType
 | 
					              segmentType
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					            ... on InitUploadAlreadyCompletedErr {
 | 
				
			||||||
 | 
					              segmentType
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            ... on TooManyInitUploadsErr {
 | 
				
			||||||
 | 
					              linksRequested
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -9,6 +9,7 @@ query GetShots(
 | 
				
			|||||||
  $includeCueObjectDistance: Boolean! = false
 | 
					  $includeCueObjectDistance: Boolean! = false
 | 
				
			||||||
  $includeCueObjectAngle: Boolean! = false
 | 
					  $includeCueObjectAngle: Boolean! = false
 | 
				
			||||||
  $includeCueBallSpeed: Boolean! = false
 | 
					  $includeCueBallSpeed: Boolean! = false
 | 
				
			||||||
 | 
					  $includeSpinType: Boolean! = false
 | 
				
			||||||
  $includeShotDirection: Boolean! = false
 | 
					  $includeShotDirection: Boolean! = false
 | 
				
			||||||
  $includeTargetPocketDistance: Boolean! = false
 | 
					  $includeTargetPocketDistance: Boolean! = false
 | 
				
			||||||
  $includeMake: Boolean! = false
 | 
					  $includeMake: Boolean! = false
 | 
				
			||||||
@@ -27,6 +28,14 @@ query GetShots(
 | 
				
			|||||||
      id
 | 
					      id
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    falsePositiveScore
 | 
					    falsePositiveScore
 | 
				
			||||||
 | 
					    video {
 | 
				
			||||||
 | 
					      stream {
 | 
				
			||||||
 | 
					        resolution {
 | 
				
			||||||
 | 
					          width
 | 
				
			||||||
 | 
					          height
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    createdAt @include(if: $includeCreatedAt)
 | 
					    createdAt @include(if: $includeCreatedAt)
 | 
				
			||||||
    updatedAt @include(if: $includeUpdatedAt)
 | 
					    updatedAt @include(if: $includeUpdatedAt)
 | 
				
			||||||
    cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
					    cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
				
			||||||
@@ -34,6 +43,7 @@ query GetShots(
 | 
				
			|||||||
      cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
					      cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
				
			||||||
      cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
					      cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
				
			||||||
      shotDirection @include(if: $includeShotDirection)
 | 
					      shotDirection @include(if: $includeShotDirection)
 | 
				
			||||||
 | 
					      spinType @include(if: $includeSpinType)
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    pocketingIntentionFeatures
 | 
					    pocketingIntentionFeatures
 | 
				
			||||||
      @include(if: $includePocketingIntentionFeatures) {
 | 
					      @include(if: $includePocketingIntentionFeatures) {
 | 
				
			||||||
@@ -44,9 +54,83 @@ query GetShots(
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					query GetSerializedShotPaths($filterInput: FilterInput!) {
 | 
				
			||||||
 | 
					  getShots(filterInput: $filterInput) {
 | 
				
			||||||
 | 
					    id
 | 
				
			||||||
 | 
					    videoId
 | 
				
			||||||
 | 
					    startFrame
 | 
				
			||||||
 | 
					    endFrame
 | 
				
			||||||
 | 
					    serializedShotPaths {
 | 
				
			||||||
 | 
					      b64EncodedBuffer
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
query GetShotAnnotationTypes {
 | 
					query GetShotAnnotationTypes {
 | 
				
			||||||
  getShotAnnotationTypes {
 | 
					  getShotAnnotationTypes {
 | 
				
			||||||
    id
 | 
					    id
 | 
				
			||||||
    name
 | 
					    name
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					query GetShotsWithMetadata(
 | 
				
			||||||
 | 
					  $filterInput: FilterInput!
 | 
				
			||||||
 | 
					  $shotsPagination: GetShotsPagination
 | 
				
			||||||
 | 
					  $limit: Int
 | 
				
			||||||
 | 
					  $includeCreatedAt: Boolean! = false
 | 
				
			||||||
 | 
					  $includeUpdatedAt: Boolean! = false
 | 
				
			||||||
 | 
					  $includeCueObjectFeatures: Boolean! = false
 | 
				
			||||||
 | 
					  $includePocketingIntentionFeatures: Boolean! = false
 | 
				
			||||||
 | 
					  $includeCueObjectDistance: Boolean! = false
 | 
				
			||||||
 | 
					  $includeCueObjectAngle: Boolean! = false
 | 
				
			||||||
 | 
					  $includeCueBallSpeed: Boolean! = false
 | 
				
			||||||
 | 
					  $includeSpinType: Boolean! = false
 | 
				
			||||||
 | 
					  $includeShotDirection: Boolean! = false
 | 
				
			||||||
 | 
					  $includeTargetPocketDistance: Boolean! = false
 | 
				
			||||||
 | 
					  $includeMake: Boolean! = false
 | 
				
			||||||
 | 
					  $includeIntendedPocketType: Boolean! = false
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					  getShotsWithMetadata(
 | 
				
			||||||
 | 
					    filterInput: $filterInput
 | 
				
			||||||
 | 
					    shotsPagination: $shotsPagination
 | 
				
			||||||
 | 
					    limit: $limit
 | 
				
			||||||
 | 
					  ) {
 | 
				
			||||||
 | 
					    count
 | 
				
			||||||
 | 
					    shots {
 | 
				
			||||||
 | 
					      id
 | 
				
			||||||
 | 
					      videoId
 | 
				
			||||||
 | 
					      startFrame
 | 
				
			||||||
 | 
					      endFrame
 | 
				
			||||||
 | 
					      user {
 | 
				
			||||||
 | 
					        id
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      falsePositiveScore
 | 
				
			||||||
 | 
					      video {
 | 
				
			||||||
 | 
					        stream {
 | 
				
			||||||
 | 
					          resolution {
 | 
				
			||||||
 | 
					            width
 | 
				
			||||||
 | 
					            height
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      serializedShotPaths {
 | 
				
			||||||
 | 
					        b64EncodedBuffer
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      createdAt @include(if: $includeCreatedAt)
 | 
				
			||||||
 | 
					      updatedAt @include(if: $includeUpdatedAt)
 | 
				
			||||||
 | 
					      cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
				
			||||||
 | 
					        cueObjectDistance @include(if: $includeCueObjectDistance)
 | 
				
			||||||
 | 
					        cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
				
			||||||
 | 
					        cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
				
			||||||
 | 
					        shotDirection @include(if: $includeShotDirection)
 | 
				
			||||||
 | 
					        spinType @include(if: $includeSpinType)
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      pocketingIntentionFeatures
 | 
				
			||||||
 | 
					        @include(if: $includePocketingIntentionFeatures) {
 | 
				
			||||||
 | 
					        targetPocketDistance @include(if: $includeTargetPocketDistance)
 | 
				
			||||||
 | 
					        make @include(if: $includeMake)
 | 
				
			||||||
 | 
					        intendedPocketType @include(if: $includeIntendedPocketType)
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -56,3 +56,10 @@ query getUsernames(
 | 
				
			|||||||
) {
 | 
					) {
 | 
				
			||||||
  getUsernames(matchString: $matchString, limit: $limit, after: $after)
 | 
					  getUsernames(matchString: $matchString, limit: $limit, after: $after)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					query GetUserTags {
 | 
				
			||||||
 | 
					  getUserTags {
 | 
				
			||||||
 | 
					    id
 | 
				
			||||||
 | 
					    name
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,7 +4,7 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) {
 | 
				
			|||||||
    totalShots
 | 
					    totalShots
 | 
				
			||||||
    makePercentage
 | 
					    makePercentage
 | 
				
			||||||
    elapsedTime
 | 
					    elapsedTime
 | 
				
			||||||
    homographyHistory {
 | 
					    currentHomography {
 | 
				
			||||||
      crop {
 | 
					      crop {
 | 
				
			||||||
        left
 | 
					        left
 | 
				
			||||||
        top
 | 
					        top
 | 
				
			||||||
@@ -118,11 +118,10 @@ query GetVideoDetails($videoId: Int!) {
 | 
				
			|||||||
query GetVideos($videoIds: [Int!]!) {
 | 
					query GetVideos($videoIds: [Int!]!) {
 | 
				
			||||||
  getVideos(videoIds: $videoIds) {
 | 
					  getVideos(videoIds: $videoIds) {
 | 
				
			||||||
    id
 | 
					    id
 | 
				
			||||||
    playlist {
 | 
					    framesPerSecond
 | 
				
			||||||
      segmentDurations
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    stream {
 | 
					    stream {
 | 
				
			||||||
      id
 | 
					      id
 | 
				
			||||||
 | 
					      streamSegmentType
 | 
				
			||||||
      segments {
 | 
					      segments {
 | 
				
			||||||
        uploaded
 | 
					        uploaded
 | 
				
			||||||
        valid
 | 
					        valid
 | 
				
			||||||
@@ -131,6 +130,9 @@ query GetVideos($videoIds: [Int!]!) {
 | 
				
			|||||||
        framesPerSecond
 | 
					        framesPerSecond
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					    playlist {
 | 
				
			||||||
 | 
					      segmentDurations
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -55,6 +55,12 @@ mutation GetHlsInitUploadLink($videoId: Int!) {
 | 
				
			|||||||
          ... on NoInitForChunkedUploadErr {
 | 
					          ... on NoInitForChunkedUploadErr {
 | 
				
			||||||
            segmentType
 | 
					            segmentType
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					          ... on InitUploadAlreadyCompletedErr {
 | 
				
			||||||
 | 
					            segmentType
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					          ... on TooManyInitUploadsErr {
 | 
				
			||||||
 | 
					            linksRequested
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -9,6 +9,11 @@ type Query {
 | 
				
			|||||||
    videoId: ID!
 | 
					    videoId: ID!
 | 
				
			||||||
    intervalDuration: Int! = 300
 | 
					    intervalDuration: Int! = 300
 | 
				
			||||||
  ): [MakePercentageIntervalGQL!]!
 | 
					  ): [MakePercentageIntervalGQL!]!
 | 
				
			||||||
 | 
					  getShotsWithMetadata(
 | 
				
			||||||
 | 
					    filterInput: FilterInput!
 | 
				
			||||||
 | 
					    shotsPagination: GetShotsPagination = null
 | 
				
			||||||
 | 
					    limit: Int! = 500
 | 
				
			||||||
 | 
					  ): GetShotsResult!
 | 
				
			||||||
  getShots(
 | 
					  getShots(
 | 
				
			||||||
    filterInput: FilterInput!
 | 
					    filterInput: FilterInput!
 | 
				
			||||||
    shotsPagination: GetShotsPagination = null
 | 
					    shotsPagination: GetShotsPagination = null
 | 
				
			||||||
@@ -48,6 +53,14 @@ type TargetMetricsGQL {
 | 
				
			|||||||
  count: Int!
 | 
					  count: Int!
 | 
				
			||||||
  makePercentage: Float
 | 
					  makePercentage: Float
 | 
				
			||||||
  averageDifficulty: Float
 | 
					  averageDifficulty: Float
 | 
				
			||||||
 | 
					  spinTypeCounts: SpinTypeCountsGQL
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type SpinTypeCountsGQL {
 | 
				
			||||||
 | 
					  follow: Int!
 | 
				
			||||||
 | 
					  draw: Int!
 | 
				
			||||||
 | 
					  center: Int!
 | 
				
			||||||
 | 
					  unknown: Int!
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
input AggregateInputGQL {
 | 
					input AggregateInputGQL {
 | 
				
			||||||
@@ -58,6 +71,7 @@ input AggregateInputGQL {
 | 
				
			|||||||
input AggregationInput @oneOf {
 | 
					input AggregationInput @oneOf {
 | 
				
			||||||
  bucketSet: BucketSetInputGQL
 | 
					  bucketSet: BucketSetInputGQL
 | 
				
			||||||
  enum: EnumAggregation
 | 
					  enum: EnumAggregation
 | 
				
			||||||
 | 
					  datetimeRange: DatetimeRangeAggregationInput
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
input BucketSetInputGQL {
 | 
					input BucketSetInputGQL {
 | 
				
			||||||
@@ -74,6 +88,38 @@ input EnumAggregation {
 | 
				
			|||||||
  feature: String!
 | 
					  feature: String!
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					input DatetimeRangeAggregationInput {
 | 
				
			||||||
 | 
					  startDatetime: DateTime!
 | 
				
			||||||
 | 
					  endDatetime: DateTime!
 | 
				
			||||||
 | 
					  interval: TimeInterval!
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					Date with time (isoformat)
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					scalar DateTime
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					input TimeInterval {
 | 
				
			||||||
 | 
					  """
 | 
				
			||||||
 | 
					  A second is the base unit and cannot be subdivided
 | 
				
			||||||
 | 
					  """
 | 
				
			||||||
 | 
					  seconds: Int = 0
 | 
				
			||||||
 | 
					  minutes: Int = 0
 | 
				
			||||||
 | 
					  hours: Int = 0
 | 
				
			||||||
 | 
					  days: Int = 0
 | 
				
			||||||
 | 
					  weeks: Int = 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  """
 | 
				
			||||||
 | 
					  Assumes a month is 30 days long
 | 
				
			||||||
 | 
					  """
 | 
				
			||||||
 | 
					  months: Int = 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  """
 | 
				
			||||||
 | 
					  Assumes a year is 365 days long
 | 
				
			||||||
 | 
					  """
 | 
				
			||||||
 | 
					  years: Int = 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
input FilterInput @oneOf {
 | 
					input FilterInput @oneOf {
 | 
				
			||||||
  andFilters: [FilterInput!]
 | 
					  andFilters: [FilterInput!]
 | 
				
			||||||
  orFilters: [FilterInput!]
 | 
					  orFilters: [FilterInput!]
 | 
				
			||||||
@@ -102,8 +148,8 @@ input FilterInput @oneOf {
 | 
				
			|||||||
  kickAngle: RangeFilter
 | 
					  kickAngle: RangeFilter
 | 
				
			||||||
  kickDistance: RangeFilter
 | 
					  kickDistance: RangeFilter
 | 
				
			||||||
  cueAngleAfterObject: RangeFilter
 | 
					  cueAngleAfterObject: RangeFilter
 | 
				
			||||||
 | 
					  spinType: [SpinTypeEnum!]
 | 
				
			||||||
  cueSpeedAfterObject: RangeFilter
 | 
					  cueSpeedAfterObject: RangeFilter
 | 
				
			||||||
  spinType: [String!]
 | 
					 | 
				
			||||||
  falsePositiveScore: RangeFilter
 | 
					  falsePositiveScore: RangeFilter
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -140,6 +186,13 @@ input ShotAnnotationInput {
 | 
				
			|||||||
  name: String!
 | 
					  name: String!
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					enum SpinTypeEnum {
 | 
				
			||||||
 | 
					  DRAW
 | 
				
			||||||
 | 
					  FOLLOW
 | 
				
			||||||
 | 
					  CENTER
 | 
				
			||||||
 | 
					  UNKNOWN
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type BucketSetGQL {
 | 
					type BucketSetGQL {
 | 
				
			||||||
  keyName: String!
 | 
					  keyName: String!
 | 
				
			||||||
  feature: String!
 | 
					  feature: String!
 | 
				
			||||||
@@ -164,6 +217,11 @@ type MakePercentageIntervalGQL {
 | 
				
			|||||||
  elapsedTime: Float!
 | 
					  elapsedTime: Float!
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetShotsResult {
 | 
				
			||||||
 | 
					  shots: [ShotGQL!]!
 | 
				
			||||||
 | 
					  count: Int
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type ShotGQL {
 | 
					type ShotGQL {
 | 
				
			||||||
  id: Int!
 | 
					  id: Int!
 | 
				
			||||||
  videoId: Int!
 | 
					  videoId: Int!
 | 
				
			||||||
@@ -181,16 +239,12 @@ type ShotGQL {
 | 
				
			|||||||
  video: VideoGQL
 | 
					  video: VideoGQL
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"""
 | 
					 | 
				
			||||||
Date with time (isoformat)
 | 
					 | 
				
			||||||
"""
 | 
					 | 
				
			||||||
scalar DateTime
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type CueObjectFeaturesGQL {
 | 
					type CueObjectFeaturesGQL {
 | 
				
			||||||
  cueObjectDistance: Float
 | 
					  cueObjectDistance: Float
 | 
				
			||||||
  cueObjectAngle: Float
 | 
					  cueObjectAngle: Float
 | 
				
			||||||
  cueBallSpeed: Float
 | 
					  cueBallSpeed: Float
 | 
				
			||||||
  shotDirection: ShotDirectionEnum
 | 
					  shotDirection: ShotDirectionEnum
 | 
				
			||||||
 | 
					  spinType: SpinTypeEnum
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type PocketingIntentionFeaturesGQL {
 | 
					type PocketingIntentionFeaturesGQL {
 | 
				
			||||||
@@ -262,6 +316,7 @@ type VideoGQL {
 | 
				
			|||||||
  stream: UploadStreamGQL
 | 
					  stream: UploadStreamGQL
 | 
				
			||||||
  playlist: HLSPlaylistGQL
 | 
					  playlist: HLSPlaylistGQL
 | 
				
			||||||
  tags: [VideoTag!]!
 | 
					  tags: [VideoTag!]!
 | 
				
			||||||
 | 
					  currentHomography: HomographyInfoGQL
 | 
				
			||||||
  homographyHistory: [HomographyInfoGQL!]!
 | 
					  homographyHistory: [HomographyInfoGQL!]!
 | 
				
			||||||
  currentProcessing: VideoProcessingGQL
 | 
					  currentProcessing: VideoProcessingGQL
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -568,15 +623,17 @@ type GetUploadLinkReturn {
 | 
				
			|||||||
union UploadLinkGetUploadLinkErrors = UploadLink | GetUploadLinkErrors
 | 
					union UploadLinkGetUploadLinkErrors = UploadLink | GetUploadLinkErrors
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type GetUploadLinkErrors {
 | 
					type GetUploadLinkErrors {
 | 
				
			||||||
  error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErr!
 | 
					  error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr!
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
union MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErr =
 | 
					union MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr =
 | 
				
			||||||
    MustHaveSetForUploadLinkErr
 | 
					    MustHaveSetForUploadLinkErr
 | 
				
			||||||
  | SegmentAlreadyUploadedErr
 | 
					  | SegmentAlreadyUploadedErr
 | 
				
			||||||
  | ProcessingFailedErr
 | 
					  | ProcessingFailedErr
 | 
				
			||||||
  | NoInitForChunkedUploadErr
 | 
					  | NoInitForChunkedUploadErr
 | 
				
			||||||
  | TooManyProfileImageUploadsErr
 | 
					  | TooManyProfileImageUploadsErr
 | 
				
			||||||
 | 
					  | InitUploadAlreadyCompletedErr
 | 
				
			||||||
 | 
					  | TooManyInitUploadsErr
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type MustHaveSetForUploadLinkErr {
 | 
					type MustHaveSetForUploadLinkErr {
 | 
				
			||||||
  resolution: Boolean
 | 
					  resolution: Boolean
 | 
				
			||||||
@@ -594,3 +651,11 @@ type ProcessingFailedErr {
 | 
				
			|||||||
type NoInitForChunkedUploadErr {
 | 
					type NoInitForChunkedUploadErr {
 | 
				
			||||||
  segmentType: StreamSegmentTypeEnum!
 | 
					  segmentType: StreamSegmentTypeEnum!
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type InitUploadAlreadyCompletedErr {
 | 
				
			||||||
 | 
					  segmentType: StreamSegmentTypeEnum!
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type TooManyInitUploadsErr {
 | 
				
			||||||
 | 
					  linksRequested: Int!
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user