import datetime import streamlit as st from config import DEFAULT_ICON from shared_page import common_page_config from queries.nfl_teams.practice_reports import scrape_all_team_injury_report, CURRENT_SEASON, CURRENT_WEEK from streamlit_filter import filter_dataframe @st.cache_data(ttl=60 * 60 * 1) def load_data(): data = scrape_all_team_injury_report() teams_list = list(data.Team.unique()) position_list = list(data.Position.unique()) status_list = list(data.game_status.unique()) last_practice_day_list = list(data["Last Practice Day"].unique()) data_load_time_str = datetime.datetime.utcnow().strftime("%m/%d/%Y %I:%M %p") return data, teams_list, position_list, status_list, last_practice_day_list, data_load_time_str def get_page(): page_title = f"Team Practice Reports - {CURRENT_SEASON} Week {CURRENT_WEEK}" 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, status_list, last_practice_day_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 positions_selected = ( st.multiselect("Position:", position_list, placeholder="Select a position to filter") or position_list ) status_selected = ( st.multiselect("Game Status:", status_list, placeholder="Select a game status to filter") or status_list ) last_practice_day_selected = ( st.multiselect( "Last Practice Day:", last_practice_day_list, placeholder="Select a day of last team practice to filter" ) or last_practice_day_list ) with st.container(): filtered_data = filter_dataframe( data[ ( data.Team.isin(teams_selected) & data.Position.isin(positions_selected) & data.game_status.isin(status_selected) & data["Last Practice Day"].isin(last_practice_day_selected) ) ] ) st.dataframe( filtered_data, hide_index=True, height=35 * (len(filtered_data) + 1) + 12, use_container_width=False, column_config={}, ) if __name__ == "__main__": get_page()