|
import datetime |
|
import streamlit as st |
|
|
|
from config import DEFAULT_ICON |
|
from shared_page import common_page_config |
|
|
|
from queries.nbcsports.player_news import get_player_news_window_hours |
|
|
|
|
|
@st.cache_data(ttl=60 * 60 * 24) |
|
def load_data(): |
|
data = get_player_news_window_hours(24) |
|
teams_list = sorted(filter(None, data.Team.unique())) |
|
position_list = data.Position.unique() |
|
data_load_time_str = datetime.datetime.utcnow().strftime("%m/%d/%Y %I:%M %p") |
|
return data, teams_list, position_list, data_load_time_str |
|
|
|
|
|
def get_page(): |
|
page_title = "Player News - Last 24 Hours" |
|
st.set_page_config(page_title=page_title, page_icon=DEFAULT_ICON, layout="wide") |
|
common_page_config() |
|
st.title(page_title) |
|
if st.button("Refresh Data"): |
|
st.cache_data.clear() |
|
data, teams_list, position_list, data_load_time_str = load_data() |
|
st.write(f"Data loaded as of: {data_load_time_str} UTC") |
|
|
|
teams_selected = st.multiselect("Team:", teams_list, placeholder="Select a team to filter") or teams_list |
|
|
|
with st.container(): |
|
filtered_data = data[(data.Team.isin(teams_selected))] |
|
st.dataframe( |
|
filtered_data, |
|
hide_index=True, |
|
height=35 * (len(filtered_data) + 1) + 12, |
|
use_container_width=True, |
|
column_order=[ |
|
"Date/Time", |
|
"Name", |
|
"Headline", |
|
"Team", |
|
"Position", |
|
], |
|
column_config={ |
|
"Date/Time": st.column_config.DatetimeColumn(format="MM-DD HH:mm"), |
|
"Team": st.column_config.TextColumn(width="small"), |
|
}, |
|
) |
|
|
|
|
|
if __name__ == "__main__": |
|
get_page() |
|
|