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,
),