from pbpstats.resources.enhanced_pbp import (
FieldGoal,
FreeThrow,
JumpBall,
Rebound,
Substitution,
Timeout,
Turnover,
)
from pbpstats.resources.enhanced_pbp.data_nba.enhanced_pbp_item import (
DataEnhancedPbpItem,
)
from pbpstats.resources.enhanced_pbp.rebound import EventOrderError
[docs]class DataRebound(Rebound, DataEnhancedPbpItem):
"""
Class for rebound events
"""
event_type = 4
def __init__(self, *args):
super().__init__(*args)
@property
def missed_shot(self):
"""
returns :obj:`~pbpstats.resources.enhanced_pbp.field_goal.FieldGoal` or
:obj:`~pbpstats.resources.enhanced_pbp.free_throw.FreeThrow` object
for shot that was missed
:raises: :obj:`~pbpstats.resources.enhanced_pbp.rebound.EventOrderError`:
If rebound event is not immediately following a missed shot event.
"""
if isinstance(self.previous_event, (FieldGoal, FreeThrow)):
if not self.previous_event.is_made:
return self.previous_event
elif (
isinstance(self.previous_event, Turnover)
and self.previous_event.is_shot_clock_violation
):
if isinstance(self.previous_event, FieldGoal):
return self.previous_event.previous_event
elif isinstance(self.previous_event, JumpBall):
prev_event = self.previous_event.previous_event
while isinstance(prev_event, (Substitution, Timeout)):
prev_event = prev_event.previous_event
if isinstance(prev_event, (FieldGoal, FreeThrow)):
return prev_event
raise EventOrderError(
f"previous event: {self.previous_event} is not a missed free throw or field goal"
)
@property
def is_placeholder(self):
"""
returns True if rebound is a placeholder event, False otherwise.
These are team rebounds on for example missed FT 1 of 2
"""
return self.event_action_type != 0 and self.player1_id == 0
@property
def oreb(self):
"""
returns True if rebound is an offensive rebound, False otherwise
"""
return self.team_id == self.missed_shot.team_id