-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathmain.py
149 lines (102 loc) · 3.84 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
#!/usr/bin/env python
import tkinter as tk
import json_handler
import plot
# global value holders
index_value = 0
expiry_value = 0
spot_price, strike_prices_list, expiry_dates_list = 0, [], []
# Start of the UI
# Create a base window for all the user interactions
def ui_space():
global index_value
indices_list = ["NIFTY", "BANKNIFTY"]
# Create an instance of tkinter frame
ui_win = tk.Tk()
# Rename window title
ui_win.title("Open interest analysis from Option chain API")
# Define the size of window or frame
ui_win.geometry("715x250")
# Place the window at the center of the screen
ui_win.eval("tk::PlaceWindow . center")
def destroyer():
ui_win.quit()
ui_win.destroy()
# Destroy windows on main window close detection and exit python
ui_win.wm_protocol ("WM_DELETE_WINDOW",destroyer)
def plot_api_data():
# forget all available widgets in the frame
for widget in ui_win.slaves():
widget.pack_forget()
global spot_price
global strike_prices_list
global expiry_dates_list
global expiry_value
expiry_value = selection.get()
print(f"Spot before passing : {spot_price}, expiry date = {expiry_value}")
plot.plot_open_interest_data(
spot=spot_price,
strikes=strike_prices_list,
expiry_list=expiry_dates_list,
expiry=expiry_value,
index=index_value,
container_window=ui_win,
)
def process_api_data():
global spot_price
global strike_prices_list
global expiry_dates_list
global expiry_value
# get the needed data from json api downloaded data for further processing
(
spot_price,
strike_prices_list,
expiry_dates_list,
) = json_handler.filter_OC_json_data()
# Update reusable elements for this use case
reusable_label.config(
text=f"{index_value} Spot : {spot_price}", font="50", fg="brown"
)
selection.set("Select Expiry Date")
new_drop_down = tk.OptionMenu(ui_win, selection, *expiry_dates_list)
new_drop_down.config(bg="lightblue")
new_drop_down.pack()
reusable_load_button.config(text="Plot OI", command=plot_api_data)
reusable_load_button.pack()
def fetch_api_data():
global index_value
index_value = selection.get()
print(f"Button works ! and current value of buffer is : {index_value}")
if index_value != 0:
# once selction is available and button pressed pack_forget existing widgets to clear view
reusable_drop_down.pack_forget()
reusable_load_button.pack_forget()
# Downloading data message
reusable_label.config(
font="50", fg="green", text="Downloading data from NSE............."
)
reusable_label.pack()
# Trigger the api request in json_handler.py
json_handler.get_OC_json(index_value)
# Add wait time for the json file to download data from API and get indented
ui_win.after(5000, process_api_data)
return
# Create the reusable storage element
selection = tk.StringVar()
selection.set("Select Index")
# Create a reusable dropdown Menu
reusable_drop_down = tk.OptionMenu(ui_win, selection, *indices_list)
reusable_drop_down.config(bg="lightblue")
reusable_drop_down.pack()
# Create a reusable load button
reusable_load_button = tk.Button(
ui_win, text="Load", command=fetch_api_data, pady=10
)
reusable_load_button.pack()
# Create a reusable label
reusable_label = tk.Label(ui_win, pady=10)
reusable_label.pack()
ui_win.mainloop()
return
if __name__ == "__main__":
ui_space()