From d5f587676a9f6785f6769167c9c5e4ab44f24c11 Mon Sep 17 00:00:00 2001 From: namuan <575441+namuan@users.noreply.github.com> Date: Mon, 23 Dec 2024 12:10:27 +0000 Subject: [PATCH] feat: Display trade strike price --- options-trade-plotter.py | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/options-trade-plotter.py b/options-trade-plotter.py index 007d75c..5d6d77a 100755 --- a/options-trade-plotter.py +++ b/options-trade-plotter.py @@ -48,6 +48,7 @@ class TradeVisualizationData: Dict[str, float] ] # Dict containing all Greeks and IV for long positions trade_date: date + trade_strike: float front_leg_expiry: date back_leg_expiry: date @@ -62,6 +63,7 @@ def __str__(self) -> str: f"Short Greeks: {self.short_greeks}\n" f"Long Greeks: {self.long_greeks}\n" f"Trade Date: {self.trade_date}\n" + f"Trade Strike: {self.trade_strike}\n" f"Front Option Expiration: {self.front_leg_expiry}\n" f"Back Option Expiration: {self.back_leg_expiry}" ) @@ -196,6 +198,7 @@ def process_trade_data(trade: Trade) -> TradeVisualizationData: short_greeks=short_greeks, long_greeks=long_greeks, trade_date=trade.trade_date, + trade_strike=trade.legs[0].strike_price, front_leg_expiry=front_leg_expiry, back_leg_expiry=back_leg_expiry, ) @@ -358,6 +361,9 @@ def create_visualization(self, trade_id: int, db: OptionsDatabase) -> go.Figure: trade = db.load_trade_with_multiple_legs(trade_id) data = TradeDataProcessor.process_trade_data(trade) + front_dte = self.calculate_days_between(data.front_leg_expiry, data.trade_date) + back_dte = self.calculate_days_between(data.back_leg_expiry, data.trade_date) + # Create figure with subplot grid: 3 rows in first column, 5 rows in second column fig = make_subplots( rows=5, @@ -462,7 +468,7 @@ def create_visualization(self, trade_id: int, db: OptionsDatabase) -> go.Figure: go.Scatter( x=data.dates, y=values, - name=f"{position_type.capitalize()} {greek.upper()}", + name=f"{position_type.capitalize()} Put", line=dict(color=color, width=self.config.line_width), mode="lines+markers", marker=dict(size=self.config.marker_size), @@ -482,12 +488,10 @@ def create_visualization(self, trade_id: int, db: OptionsDatabase) -> go.Figure: ) # Update layout - front_dte = self.calculate_days_between(data.front_leg_expiry, data.trade_date) - back_dte = self.calculate_days_between(data.back_leg_expiry, data.trade_date) fig.update_layout( height=self.config.figure_height, title=dict( - text=f"Trade Date: {data.trade_date} Front Expiry: {data.front_leg_expiry} ({front_dte}) Back Expiry: {data.back_leg_expiry} ({back_dte})", + text=f"Trade Date: {data.trade_date} Strike {data.trade_strike} Front Expiry: {data.front_leg_expiry} ({front_dte}) Back Expiry: {data.back_leg_expiry} ({back_dte})", font=dict(family=self.FONT, size=16, color="#2C3E50"), x=0.5, ),