import streamlit as st import pandas as pd from datetime import datetime import glob import os # Function to check user credentials def check_credentials(username, password): return username == "Josia" and password == "admin" # Function to save data to CSV def save_data(form_data, username): # Convert to DataFrame and append to CSV. Here we assume that all CSV files are stored in the current directory. df = pd.DataFrame([form_data]) csv_path = f'collected_data_{username}.csv' df.to_csv(csv_path, mode='a', header=not os.path.exists(csv_path), index=False) # Function to list all CSV files created by the users def list_csv_files(): # List all CSV files in the current directory return glob.glob('collected_data_*.csv') # Main App def main(): st.set_page_config(page_title="Frijoles", layout="wide") st.sidebar.title("Common Bean Data Collection App") st.sidebar.header("Please Log In") username = st.sidebar.text_input("Username") password = st.sidebar.text_input("Password", type="password") if st.sidebar.button("Login"): if check_credentials(username, password): st.session_state['authenticated'] = True else: st.session_state['authenticated'] = False st.sidebar.error("The username or password you entered is incorrect.") if 'authenticated' not in st.session_state: st.session_state['authenticated'] = False if st.session_state['authenticated']: st.title('Welcome to Common Bean Data Collection App') # Form for new data collection st.header("Collect new data") with st.form("new_data_form"): # Collect necessary information from user disease_type = st.selectbox("Select disease type", ['ALS', 'CBB']) region = st.selectbox("Select region", ['Selian', 'Uyole', 'Maluku']) genotype = st.selectbox("Select genotype", ['Genotype A', 'Genotype B']) growth_level = st.selectbox("Select plant growth level", ['First Trifoliate', 'Second Trifoliate']) plant_number = st.selectbox("Select plant number", list(range(1, 11))) leaf_number = st.selectbox("Select leaf number", list(range(1, 11))) scan_number = st.selectbox("Select scan number", list(range(1, 11))) visual_score = st.slider("Visual Score", 1, 9, 1) submitted = st.form_submit_button("Save") if submitted: # Construct the form data to save form_data = { "Date": datetime.now().strftime("%Y-%m-%d"), "Time": datetime.now().strftime("%H:%M:%S"), "Disease Type": disease_type, "Region": region, "Genotype": genotype, "Growth Level": growth_level, "Plant Number": plant_number, "Leaf Number": leaf_number, "Scan Number": scan_number, "Visual Score": visual_score } save_data(form_data, username) st.success("Data saved successfully!") # Button to open ScanSpectrum app (Placeholder for actual URL scheme) st.markdown("Please use your mobile device to open the ScanSpectrum app and perform the scan.") st.markdown("", unsafe_allow_html=True) # Functionality to preview CSV files st.header("Preview Saved Data") all_csv_files = list_csv_files() selected_csv = st.selectbox("Select a CSV file to preview", all_csv_files) if st.button('Show Selected CSV'): if selected_csv: data_to_show = pd.read_csv(selected_csv) st.write(f"Preview of {selected_csv}:") st.dataframe(data_to_show) else: st.error("No CSV file selected.") else: st.warning("You need to login to access the data collection form.") # Run the main app if __name__ == "__main__": main()