Spaces:
Sleeping
Sleeping
Commit
•
996431a
1
Parent(s):
0919209
Delete app.py
Browse files
app.py
DELETED
@@ -1,117 +0,0 @@
|
|
1 |
-
import calendar # Core Python Module
|
2 |
-
from datetime import datetime # Core Python Module
|
3 |
-
|
4 |
-
import plotly.graph_objects as go # pip install plotly
|
5 |
-
import streamlit as st # pip install streamlit
|
6 |
-
from streamlit_option_menu import option_menu # pip install streamlit-option-menu
|
7 |
-
|
8 |
-
import database as db # local import
|
9 |
-
|
10 |
-
# # -------------- SETTINGS --------------
|
11 |
-
incomes = ["Salary", "Blog", "Other Income"]
|
12 |
-
expenses = ["Rent", "Utilities", "Groceries", "Car", "Other Expenses", "Saving"]
|
13 |
-
currency = "USD"
|
14 |
-
page_title = "Income and Expense Tracker"
|
15 |
-
page_icon = ":money_with_wings:" # emojis: https://www.webfx.com/tools/emoji-cheat-sheet/
|
16 |
-
layout = "centered"
|
17 |
-
# # --------------------------------------
|
18 |
-
|
19 |
-
st.set_page_config(page_title=page_title, page_icon=page_icon, layout=layout)
|
20 |
-
st.title(page_title + " " + page_icon)
|
21 |
-
|
22 |
-
# # --- DROP DOWN VALUES FOR SELECTING THE PERIOD ---
|
23 |
-
years = [datetime.today().year, datetime.today().year + 1]
|
24 |
-
months = list(calendar.month_name[1:])
|
25 |
-
|
26 |
-
|
27 |
-
# # # --- DATABASE INTERFACE --- Data Key: a0yqzckztju_L4gxuEg2cSQWAsaE8digGs8pgfhNTAdn
|
28 |
-
def get_all_periods():
|
29 |
-
items = db.fetch_all_periods()
|
30 |
-
periods = [item["key"] for item in items]
|
31 |
-
return periods
|
32 |
-
|
33 |
-
|
34 |
-
# # # --- HIDE STREAMLIT STYLE ---
|
35 |
-
hide_st_style = """
|
36 |
-
<style>
|
37 |
-
#MainMenu {visibility: hidden;}
|
38 |
-
footer {visibility: hidden;}
|
39 |
-
header {visibility: hidden;}
|
40 |
-
</style>
|
41 |
-
"""
|
42 |
-
st.markdown(hide_st_style, unsafe_allow_html=True)
|
43 |
-
|
44 |
-
# # # --- NAVIGATION MENU ---
|
45 |
-
selected = option_menu(
|
46 |
-
menu_title=None,
|
47 |
-
options=["Data Entry", "Data Visualization"],
|
48 |
-
icons=["pencil-fill", "bar-chart-fill"], # https://icons.getbootstrap.com/
|
49 |
-
orientation="horizontal",
|
50 |
-
)
|
51 |
-
|
52 |
-
# # # --- INPUT & SAVE PERIODS ---
|
53 |
-
if selected == "Data Entry":
|
54 |
-
st.header(f"Data Entry in {currency}")
|
55 |
-
with st.form("entry_form", clear_on_submit=True):
|
56 |
-
col1, col2 = st.columns(2)
|
57 |
-
col1.selectbox("Select Month:", months, key="month")
|
58 |
-
col2.selectbox("Select Year:", years, key="year")
|
59 |
-
|
60 |
-
"---"
|
61 |
-
with st.expander("Income"):
|
62 |
-
for income in incomes:
|
63 |
-
st.number_input(f"{income}:", min_value=0, format="%i", step=10, key=income)
|
64 |
-
with st.expander("Expenses"):
|
65 |
-
for expense in expenses:
|
66 |
-
st.number_input(f"{expense}:", min_value=0, format="%i", step=10, key=expense)
|
67 |
-
with st.expander("Comment"):
|
68 |
-
comment = st.text_area("", placeholder="Enter a comment here ...")
|
69 |
-
|
70 |
-
"---"
|
71 |
-
submitted = st.form_submit_button("Save Data")
|
72 |
-
if submitted:
|
73 |
-
period = str(st.session_state["year"]) + "_" + str(st.session_state["month"])
|
74 |
-
incomes = {income: st.session_state[income] for income in incomes}
|
75 |
-
expenses = {expense: st.session_state[expense] for expense in expenses}
|
76 |
-
db.insert_period(period, incomes, expenses, comment)
|
77 |
-
st.success("Data saved!")
|
78 |
-
|
79 |
-
|
80 |
-
# # --- PLOT PERIODS ---
|
81 |
-
if selected == "Data Visualization":
|
82 |
-
st.header("Data Visualization")
|
83 |
-
with st.form("saved_periods"):
|
84 |
-
period = st.selectbox("Select Period:", get_all_periods())
|
85 |
-
submitted = st.form_submit_button("Plot Period")
|
86 |
-
if submitted:
|
87 |
-
# Get data from database
|
88 |
-
period_data = db.get_period(period)
|
89 |
-
comment = period_data.get("comment")
|
90 |
-
expenses = period_data.get("expenses")
|
91 |
-
incomes = period_data.get("incomes")
|
92 |
-
|
93 |
-
# Create metrics
|
94 |
-
total_income = sum(incomes.values())
|
95 |
-
total_expense = sum(expenses.values())
|
96 |
-
remaining_budget = total_income - total_expense
|
97 |
-
col1, col2, col3 = st.columns(3)
|
98 |
-
col1.metric("Total Income", f"{total_income} {currency}")
|
99 |
-
col2.metric("Total Expense", f"{total_expense} {currency}")
|
100 |
-
col3.metric("Remaining Budget", f"{remaining_budget} {currency}")
|
101 |
-
st.text(f"Comment: {comment}")
|
102 |
-
|
103 |
-
# # Create sankey chart
|
104 |
-
label = list(incomes.keys()) + ["Total Income"] + list(expenses.keys())
|
105 |
-
source = list(range(len(incomes))) + [len(incomes)] * len(expenses)
|
106 |
-
target = [len(incomes)] * len(incomes) + [label.index(expense) for expense in expenses.keys()]
|
107 |
-
value = list(incomes.values()) + list(expenses.values())
|
108 |
-
|
109 |
-
# # Data to dict, dict to sankey
|
110 |
-
link = dict(source=source, target=target, value=value)
|
111 |
-
node = dict(label=label, pad=20, thickness=30, color="#198AAF")
|
112 |
-
data = go.Sankey(link=link, node=node)
|
113 |
-
|
114 |
-
# # Plot it!
|
115 |
-
fig = go.Figure(data)
|
116 |
-
fig.update_layout(margin=dict(l=0, r=0, t=5, b=5))
|
117 |
-
st.plotly_chart(fig, use_container_width=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|